@charset "UTF-8";
html {
  font-size: 12px;
  color: #303030;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  height: 100%;
}

body {
  height: 100%;
}

#wrap {
  margin: auto;
  overflow: hidden;
  position: relative;
  background-color: #fff;
  -webkit-filter: drop-shadow(0 0 5px #a5b7cc);
          filter: drop-shadow(0 0 5px #a5b7cc);
}
#wrap nav#top {
  background-image: url(../images/bg-header.png);
  background-repeat: repeat-x;
  background-size: contain;
  -webkit-filter: drop-shadow(0 0 5px #030303);
          filter: drop-shadow(0 0 5px #030303);
  padding: 5px 0;
}
@media (max-width: 768px) {
  #wrap nav#top {
    background-color: #fff;
  }
}
#wrap nav#top .logo {
  padding-top: 6px;
  padding-left: 20px;
}
#wrap nav#top .tel {
  position: absolute;
  right: 20px;
  text-align: center;
  padding-top: 10px;
}
#wrap nav#top .tel .material-symbols-outlined {
  font-size: 30px;
  color: #00726b;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 200, "opsz" 48;
}
#wrap nav#top .tel a {
  font-family: vag-rundschrift-d, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.8rem;
  text-decoration: none;
  color: #009e91;
}
@media (max-width: 768px) {
  #wrap nav#top .tel {
    display: none;
  }
}
#wrap #slider {
  height: 100vh;
  z-index: -2;
  position: relative;
}
#wrap #slider .catch {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: sticky;
  top: 35%;
  -webkit-filter: drop-shadow(0 0 1mm rgb(0, 0, 0));
          filter: drop-shadow(0 0 1mm rgb(0, 0, 0));
  padding: 10px;
}
@media (max-width: 768px) {
  #wrap #slider .catch {
    top: 20%;
  }
}
@-webkit-keyframes bgloop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: 1280px 0;
  }
}
@keyframes bgloop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: 1280px 0;
  }
}
#wrap #slider-page {
  height: 150px;
  z-index: -2;
  position: relative;
}
#wrap #slider-page .catch {
  margin-top: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@keyframes bgloop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: 1280px 0;
  }
}
#wrap #top-page {
  padding-top: 30px;
}
#wrap .footnav {
  background-color: #009e91;
  margin-top: 20px;
  padding: 20px;
  color: #fff;
}
#wrap .footnav p {
  font-size: 1.2rem;
}
#wrap .footnav .cehck {
  background-color: #fff;
}
#wrap .footnav .tel {
  text-align: center;
  padding-top: 10px;
}
#wrap .footnav .tel .material-symbols-outlined {
  font-size: 30px;
  color: #fff;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 200, "opsz" 48;
}
#wrap .footnav .tel a {
  font-family: vag-rundschrift-d, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.8rem;
  text-decoration: none;
  color: #fff;
  white-space: nowrap;
  line-height: 1;
}
@media (max-width: 768px) {
  #wrap .footnav .tel {
    display: none;
  }
}
#wrap footer {
  background-color: #004a48;
  color: #fff;
  padding: 20px;
}
#wrap footer a {
  color: #fff;
}
#wrap footer .copyright {
  font-family: rustica, sans-serif;
  font-weight: 700;
  font-style: normal;
}
#wrap footer .copyright p {
  color: #fff;
  margin-bottom: 0;
}
#wrap footer br {
  display: none;
}
@media (max-width: 576px) {
  #wrap footer br {
    display: inherit;
  }
}

#bottom {
  text-align: center;
  width: 100%;
  padding: 10px;
  bottom: 0;
  background: rgba(255, 255, 255, 0.9);
  display: none !important;
}
@media (max-width: 768px) {
  #bottom {
    display: block !important;
  }
}
#bottom .anim-box.poyopoyo {
  -webkit-animation: poyopoyo 2s ease-out infinite;
          animation: poyopoyo 2s ease-out infinite;
  opacity: 1;
}
@-webkit-keyframes poyopoyo {
  0%, 40%, 60%, 80% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  50%, 70% {
    -webkit-transform: scale(0.96);
            transform: scale(0.96);
  }
}
@keyframes poyopoyo {
  0%, 40%, 60%, 80% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  50%, 70% {
    -webkit-transform: scale(0.96);
            transform: scale(0.96);
  }
}

body {
  font-family: YakuHanJP, "source-han-sans-cjk-ja", sans-serif;
  font-style: normal;
  font-weight: 300;
}

nav#top {
  border-top: 5px solid #00726b;
  padding: 0;
}
nav#top h1 {
  background-image: url(../images/mark.png);
  background-repeat: no-repeat;
  padding-left: 65px;
  height: 60px;
  font-size: 0.8rem;
  font-weight: normal;
  margin-right: 20px;
  margin-bottom: 0;
  color: #272727;
}
nav#top h1 span {
  color: #04625f;
  font-size: 1rem;
  display: block;
  font-weight: normal;
}
@media (max-width: 1235px) {
  nav#top h1 span {
    font-size: 0.8rem;
  }
}

#top-page h1 {
  color: #fd7279;
  font-style: normal;
  font-weight: 700;
}
#top-page h2 {
  color: #004A48;
  line-height: 32px;
  padding: 10px 0;
  position: relative;
  margin-bottom: 30px;
  font-family: rift, sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 4rem;
  border-bottom: 1px solid #004A48;
  margin-bottom: 50px;
}
#top-page h2 span {
  color: #009e96;
  font-size: 1.2rem;
}
#top-page h2 span.note {
  font-weight: normal;
  font-size: 1.2rem;
  letter-spacing: 0.8rem;
  position: absolute;
  bottom: -35px;
  left: 0;
}
#top-page h2 a {
  position: absolute;
  right: 0;
  font-size: 1.2rem;
}
@media (max-width: 768px) {
  #top-page h2 a {
    display: block;
    text-align: right;
    width: 100%;
    bottom: -40px;
  }
}
#top-page h3 {
  font-weight: 700;
  color: #14327a;
  font-size: 1.6rem;
}
#top-page h4 {
  font-weight: 700;
  font-size: 1.4rem;
  padding-left: 10px;
  line-height: 36px;
}
#top-page h4.card-title {
  color: #fff;
}
#top-page h4.org {
  background-color: #fd7279;
}
#top-page h4.pnk {
  background-color: #f598a0;
}
#top-page p {
  color: #364960;
  font-size: 1.4rem;
}
#top-page ol,
#top-page ul {
  color: #364960;
  font-size: 1.3rem;
}

.post h2 {
  color: #004A48;
  line-height: 32px;
  padding: 10px 0 5px;
  font-weight: 700;
  font-size: 1.6rem;
  border-bottom: solid 5px #009e91;
  position: relative;
  margin-bottom: 30px;
}
@media (max-width: 768px) {
  .post h2 {
    margin-bottom: 50px;
  }
}
.post h2 img {
  margin-right: 10px;
}
.post h2 span {
  color: #009e96;
  font-weight: normal;
}
.post h2:after {
  position: absolute;
  content: " ";
  display: block;
  border-bottom: solid 5px #004A48;
  bottom: -5px;
  width: 300px;
}
@media (max-width: 768px) {
  .post h2:after {
    width: 50%;
  }
}
.post h2 a {
  position: absolute;
  right: 0;
  font-size: 1.4rem;
}
@media (max-width: 768px) {
  .post h2 a {
    display: block;
    text-align: center;
    width: 100%;
    bottom: -40px;
  }
}
.post h3 {
  font-weight: 700;
  font-size: 1.3rem;
  background-image: url(../images/bg-h3.png);
  border-top: 10px solid #d5d5d5;
  padding-top: 12px;
  padding-bottom: 12px;
  padding-left: 20px;
  margin-bottom: 20px;
}
.post h4 {
  color: #1f497d;
  font-weight: 700;
  font-size: 1.4rem;
  margin-left: 20px;
  margin-bottom: 20px;
  padding-bottom: 10px;
  background-image: url(../images/bg-h4.png);
  background-repeat: repeat-x;
  background-position: bottom;
}
.post h5 {
  color: #1f497d;
  font-weight: 700;
  font-size: 1.4rem;
  margin-left: 20px;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 1px dotted #1f497d;
}
.post p {
  color: #364960;
  font-size: 1.4rem;
  padding-left: 2rem;
  padding-right: 2rem;
}
.post ol,
.post ul {
  color: #364960;
  font-size: 1.4rem;
}
.post ul {
  list-style: none;
}
.post ul li {
  background-image: url(../images/bg-list.png);
  background-repeat: no-repeat;
  background-position: left 7px;
  padding-left: 15px;
  margin-bottom: 15px;
  font-size: 1.4rem;
}
.post .wp-block-table {
  padding-left: 2rem;
  padding-right: 2rem;
}
.post table {
  font-size: 1.4rem;
  margin: 0;
  margin-bottom: 20px;
}
.post table th,
.post table td {
  border: 1px solid #dddddd;
  padding: 10px;
  white-space: nowrap;
}
.post table th {
  background-color: #f9f9f9;
}
.post .greeting p {
  font-size: 1.3rem;
  margin-left: 40px;
}
.post .greeting-photo p {
  font-size: 1.8rem;
  margin-left: 0;
}
.post .greeting-photo p span {
  font-size: 1.2rem;
  display: block;
}

.archive h2 {
  color: #303030;
  line-height: 32px;
  padding: 10px 0;
  font-weight: 700;
  border-bottom: solid 5px #e1e1e1;
  position: relative;
  margin-bottom: 30px;
}
@media (max-width: 768px) {
  .archive h2 {
    margin-bottom: 50px;
  }
}
.archive h2 img {
  margin-right: 10px;
}
.archive h2 span {
  color: #009e96;
  font-weight: normal;
}
.archive h2:after {
  position: absolute;
  content: " ";
  display: block;
  border-bottom: solid 5px #3389eb;
  bottom: -5px;
  width: 300px;
}
@media (max-width: 768px) {
  .archive h2:after {
    width: 50%;
  }
}
.archive h3 {
  font-weight: 700;
  font-size: 1.4rem;
  background-image: url(../images/bg-h3.png);
  border-top: 10px solid #d5d5d5;
  padding-top: 6px;
  padding-bottom: 12px;
  padding-left: 20px;
  margin-bottom: 20px;
}
.archive p {
  color: #364960;
  font-size: 1.4rem;
}

.att {
  font-size: 14pt;
}

.sub ul {
  font-size: 12pt;
}

.company h3 {
  background-image: url(../images/bg-company-h3.png);
  border-top: none !important;
  color: #fff !important;
  text-align: center;
  padding: 14px;
  font-size: 1.8rem !important;
  font-weight: normal !important;
  margin-bottom: 20px;
}

.btn,
a.btn,
button.btn {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 0.6rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
  border-radius: 0.5rem;
}

a.btn--yellow {
  color: #000;
  background-color: #fff100;
  border-bottom: 5px solid #ccc100;
}

a.btn--yellow:hover {
  margin-top: 3px;
  color: #000;
  background: #fff20a;
  border-bottom: 2px solid #ccc100;
}

.logo button {
  margin-top: 15px;
  position: absolute;
  right: 20px;
  top: 0;
}

nav#top {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
      justify-content: space-around;
}
@media (max-width: 768px) {
  nav#top {
    display: block;
  }
}
nav#top a.tel {
  display: block;
  text-align: right;
  margin-top: 20px;
  margin-bottom: 20px;
}
@media (max-width: 1235px) {
  nav#top a.tel img {
    width: 60%;
    height: auto;
  }
}
@media (max-width: 992px) {
  nav#top a.tel {
    display: none;
  }
}
nav#top ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  list-style: none;
  height: 100%;
  margin: 0;
  margin-right: 20px;
}
nav#top ul li {
  height: 100%;
  background-image: url(../images/bg-nava.png);
  background-repeat: no-repeat;
  display: block;
}
@media (max-width: 992px) {
  nav#top ul li {
    background-image: none;
  }
}
nav#top ul li:last-child {
  background: url(../images/bg-nava.png), url(../images/bg-nava.png);
  background-repeat: no-repeat;
  background-position: top left, top right;
}
@media (max-width: 992px) {
  nav#top ul li:last-child {
    background-image: none;
  }
}
nav#top ul li a {
  position: relative;
  color: #303030;
  text-decoration: none;
  text-align: center;
  font-size: 1.3rem;
  margin-left: 15px;
  margin-right: 15px;
  white-space: nowrap;
  line-height: 60px;
}
@media (max-width: 1235px) {
  nav#top ul li a {
    font-size: 1.1rem;
    margin-left: 10px;
    margin-right: 10px;
  }
}
@media (max-width: 992px) {
  nav#top ul li a {
    font-size: 1rem;
    width: 100%;
  }
}
nav#top ul li a::after {
  position: absolute;
  bottom: -4px;
  left: 0;
  content: "";
  width: 100%;
  height: 3px;
  background: #000066;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: center top;
          transform-origin: center top;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
nav#top ul li a:hover {
  color: #303030;
}
nav#top ul li a:hover::after {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}

.footnav {
  padding-bottom: 0 !important;
}
.footnav .foot-bana {
  margin-bottom: 15px;
  white-space: nowrap;
}
.footnav .foot-bana p {
  margin-bottom: 0;
}

footer {
  font-size: 1.2rem;
}
footer nav#foot-nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}
footer nav#foot-nav ul li a {
  font-weight: normal;
  margin-right: 15px;
  text-decoration: none;
}
footer nav#foot-nav ul li a span {
  color: #009E91;
  font-size: 1.2rem;
}

#bottom .tel {
  text-align: center;
  padding-top: 10px;
}
#bottom .tel .material-symbols-outlined {
  font-size: 30px;
  color: #00726b;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 200, "opsz" 48;
}
#bottom .tel a {
  font-family: vag-rundschrift-d, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.8rem;
  text-decoration: none;
  color: #009e91;
}

#top-page .news dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: 30px;
}
@media (max-width: 992px) {
  #top-page .news dl {
    display: block;
  }
}
#top-page .news dl dt {
  font-size: 1.4rem;
  margin-right: 15px;
  color: #004A48;
}
#top-page .news dl dd {
  font-size: 1.4rem;
}
@media (max-width: 992px) {
  #top-page .news dl dt, #top-page .news dl dd {
    width: 100%;
  }
}

.att {
  border: solid 2px #289bd8;
  padding: 20px;
}

.sub {
  background-color: #d8e5e8;
}

.wp-block-button__link {
  background-color: #fd7279 !important;
}

.panlist {
  font-size: 1rem;
  padding-top: 10px;
  padding-bottom: 10px;
}

.case .row {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.case .row .case-detail a {
  display: block;
  text-decoration: none;
  border-radius: 10px;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  padding: 2px;
  margin-bottom: 15px;
  background-color: #f7f7f7;
  overflow: hidden;
}
.case .row .case-detail a:hover {
  color: #fff !important;
  background-color: #009e96;
  background-image: url(../images/bg-company-h3.png);
  border-radius: 10px;
}
.case .row .case-detail a:hover p {
  color: #fff !important;
}
.case .row .case-detail a img {
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px 10px 0 0;
}
.case .row .case-detail a p {
  padding-top: 10px;
  font-size: 1.2rem !important;
}
.case .row .case-detail a p span {
  font-size: 1rem;
}

.case .row {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.case .row .case-detail a img {
  width: 100%;
  aspect-ratio: 3/2;
}
@media (max-width: 768px) {
  .case .row .case-detail a img {
    aspect-ratio: 16/9;
  }
}

.archive .case .row .case-detail a img {
  min-width: 200px;
  width: 100%;
  height: 200px;
}

body {
  -webkit-overflow-scrolling: touch;
}

.bg ul {
  padding-top: 0;
}

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
1.0 Normalize
2.0 Accessibility
3.0 Alignments
4.0 Clearings
5.0 Typography
6.0 Forms
7.0 Formatting
8.0 Lists
9.0 Tables
10.0 Links
11.0 Featured Image Hover
12.0 Navigation
13.0 Layout
   13.1 Header
   13.2 Front Page
   13.3 Regular Content
   13.4 Posts
   13.5 Pages
   13.6 Footer
14.0 Comments
15.0 Widgets
16.0 Media
   16.1 Galleries
17.0 Customizer
18.0 SVGs Fallbacks
19.0 Media Queries
20.0 Print
--------------------------------------------------------------*/
/*--------------------------------------------------------------
1.0 Normalize
Styles based on Normalize v5.0.0 @link https://github.com/necolas/normalize.css
--------------------------------------------------------------*/
svg:not(:root) {
  overflow: hidden;
}

button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

[type=checkbox],
[type=radio] {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

/*--------------------------------------------------------------
2.0 Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers. */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  overflow: hidden;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important; /* Many screen reader and browser combinations announce broken words as they would appear visually. */
}

.screen-reader-text:focus {
  background-color: #f1f1f1;
  border-radius: 3px;
  -webkit-box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  color: #21759b;
  display: block;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 700;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000; /* Above WP toolbar. */
}

/*--------------------------------------------------------------
4.0 Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.entry-footer:before,
.entry-footer:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after,
.nav-links:before,
.nav-links:after,
.pagination:before,
.pagination:after,
.comment-author:before,
.comment-author:after,
.widget-area:before,
.widget-area:after,
.widget:before,
.widget:after,
.comment-meta:before,
.comment-meta:after {
  content: "";
  display: table;
  table-layout: fixed;
}

.clear:after,
.entry-content:after,
.entry-footer:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after,
.nav-links:after,
.pagination:after,
.comment-author:after,
.widget-area:after,
.widget:after,
.comment-meta:after {
  clear: both;
}

/*--------------------------------------------------------------
5.0 Typography
--------------------------------------------------------------*/
/*--------------------------------------------------------------
5.5 Typography Overrides
--------------------------------------------------------------*/
/* General paragraph styling */
p {
  font-size: 1.3rem;
  line-height: 1.6;
}

/* General table styling */
table {
  font-size: 1.3rem;
}

/* General ul, ol styling */
ul, ol {
  font-size: 1.3rem;
}

ul li, ol li {
  font-size: 1.3rem;
}

/*--------------------------------------------------------------
6.0 Forms
--------------------------------------------------------------*/
/* Form Labels */
label {
  color: #333;
  display: block;
  font-weight: 600;
  margin-bottom: 0.5em;
  font-size: 1.1rem;
  letter-spacing: 0.5px;
}

fieldset {
  margin-bottom: 1.5em;
  border: none;
  padding: 0;
}

/* Modern Form Inputs */
input[type=text],
input[type=email],
input[type=url],
input[type=password],
input[type=search],
input[type=number],
input[type=tel],
input[type=range],
input[type=date],
input[type=month],
input[type=week],
input[type=time],
input[type=datetime],
input[type=datetime-local],
input[type=color],
textarea {
  color: #333;
  background: #fff;
  border: 2px solid #e1e5e9;
  border-radius: 8px;
  display: block;
  padding: 12px 16px;
  width: 100%;
  font-size: 18px;
  line-height: 1.5;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

input[type=text]::-webkit-input-placeholder, input[type=email]::-webkit-input-placeholder, input[type=url]::-webkit-input-placeholder, input[type=password]::-webkit-input-placeholder, input[type=search]::-webkit-input-placeholder, input[type=number]::-webkit-input-placeholder, input[type=tel]::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #8a8a8a;
  font-style: italic;
}

input[type=text]::-moz-placeholder, input[type=email]::-moz-placeholder, input[type=url]::-moz-placeholder, input[type=password]::-moz-placeholder, input[type=search]::-moz-placeholder, input[type=number]::-moz-placeholder, input[type=tel]::-moz-placeholder, textarea::-moz-placeholder {
  color: #8a8a8a;
  font-style: italic;
}

input[type=text]:-ms-input-placeholder, input[type=email]:-ms-input-placeholder, input[type=url]:-ms-input-placeholder, input[type=password]:-ms-input-placeholder, input[type=search]:-ms-input-placeholder, input[type=number]:-ms-input-placeholder, input[type=tel]:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #8a8a8a;
  font-style: italic;
}

input[type=text]::-ms-input-placeholder, input[type=email]::-ms-input-placeholder, input[type=url]::-ms-input-placeholder, input[type=password]::-ms-input-placeholder, input[type=search]::-ms-input-placeholder, input[type=number]::-ms-input-placeholder, input[type=tel]::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: #8a8a8a;
  font-style: italic;
}

input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=url]::placeholder,
input[type=password]::placeholder,
input[type=search]::placeholder,
input[type=number]::placeholder,
input[type=tel]::placeholder,
textarea::placeholder {
  color: #8a8a8a;
  font-style: italic;
}

/* Focus States */
input[type=text]:focus,
input[type=email]:focus,
input[type=url]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=number]:focus,
input[type=tel]:focus,
input[type=range]:focus,
input[type=date]:focus,
input[type=month]:focus,
input[type=week]:focus,
input[type=time]:focus,
input[type=datetime]:focus,
input[type=datetime-local]:focus,
input[type=color]:focus,
textarea:focus {
  color: #222;
  border-color: #007cba;
  -webkit-box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1), 0 4px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1), 0 4px 8px rgba(0, 0, 0, 0.1);
  outline: none;
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
}

/* Textarea specific */
textarea {
  min-height: 120px;
  resize: vertical;
}

select {
  border: 2px solid #e1e5e9;
  border-radius: 8px;
  height: 52px;
  max-width: 100%;
  padding: 0 16px;
  font-size: 18px;
  background: #fff;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

select:focus {
  border-color: #007cba;
  -webkit-box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1);
          box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1);
  outline: none;
}

input[type=radio]:focus,
input[type=checkbox]:focus {
  outline: 2px solid #007cba;
  outline-offset: 2px;
}

input[type=radio],
input[type=checkbox] {
  margin-right: 0.75em;
  -webkit-transform: scale(1.2);
          transform: scale(1.2);
}

input[type=radio] + label,
input[type=checkbox] + label {
  font-weight: 400;
  cursor: pointer;
}

/* Modern Buttons */
button,
input[type=button],
input[type=submit] {
  background: linear-gradient(135deg, #007cba 0%, #005a87 100%);
  border: none;
  border-radius: 8px;
  color: #fff;
  cursor: pointer;
  display: inline-block;
  font-size: 18px;
  font-weight: 600;
  line-height: 1;
  padding: 16px 32px;
  text-shadow: none;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-box-shadow: 0 4px 12px rgba(0, 124, 186, 0.3);
          box-shadow: 0 4px 12px rgba(0, 124, 186, 0.3);
  letter-spacing: 0.5px;
  position: relative;
  overflow: hidden;
}

button::before,
input[type=button]::before,
input[type=submit]::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left top, right top, from(transparent), color-stop(rgba(255, 255, 255, 0.2)), to(transparent));
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
  -webkit-transition: left 0.5s;
  transition: left 0.5s;
}

button:hover::before,
input[type=button]:hover::before,
input[type=submit]:hover::before {
  left: 100%;
}

input + button,
input + input[type=button],
input + input[type=submit] {
  padding: 12px 24px;
}

button.secondary,
input[type=reset],
input[type=button].secondary,
input[type=reset].secondary,
input[type=submit].secondary {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  color: #495057;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

:not(.mejs-button) > button:hover,
:not(.mejs-button) > button:focus,
input[type=button]:hover,
input[type=button]:focus,
input[type=submit]:hover,
input[type=submit]:focus {
  background: linear-gradient(135deg, #005a87 0%, #004065 100%);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 6px 16px rgba(0, 124, 186, 0.4);
          box-shadow: 0 6px 16px rgba(0, 124, 186, 0.4);
}

button.secondary:hover,
button.secondary:focus,
input[type=reset]:hover,
input[type=reset]:focus,
input[type=button].secondary:hover,
input[type=button].secondary:focus,
input[type=reset].secondary:hover,
input[type=reset].secondary:focus,
input[type=submit].secondary:hover,
input[type=submit].secondary:focus {
  background: linear-gradient(135deg, #e9ecef 0%, #dee2e6 100%);
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Contact Page Specific Styles */
.contact-section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 20px;
}

.contact-header {
  text-align: center;
  margin-bottom: 60px;
}

.contact-header .contact-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: #333;
  margin-bottom: 16px;
  position: relative;
}

.contact-header .contact-title::after {
  content: "";
  position: absolute;
  bottom: -8px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 80px;
  height: 4px;
  background: linear-gradient(135deg, #007cba 0%, #005a87 100%);
  border-radius: 2px;
}

.contact-header .contact-subtitle {
  font-size: 1.25rem;
  color: #666;
  margin: 0;
  font-weight: 400;
}

.contact-container {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 60px 400px;
  grid-template-columns: 1fr 400px;
  gap: 60px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}

@media (max-width: 768px) {
  .contact-container {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
.contact-form-wrapper .form-container {
  background: #fff;
  padding: 40px;
  border-radius: 16px;
  -webkit-box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
          box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
  border: 1px solid #f0f0f0;
}

.contact-info-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 30px;
}

.contact-method {
  background: #fff;
  padding: 32px;
  border-radius: 16px;
  -webkit-box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
          box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  border: 1px solid #f0f0f0;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.contact-method:hover {
  -webkit-transform: translateY(-4px);
          transform: translateY(-4px);
  -webkit-box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
          box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

.contact-method .contact-icon {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #007cba 0%, #005a87 100%);
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 20px;
}

.contact-method .contact-icon i {
  font-size: 24px;
  color: #fff;
  font-style: normal;
}

.contact-method h3 {
  font-size: 1.3rem;
  font-weight: 600;
  color: #333;
  margin-bottom: 12px;
}

.contact-method p {
  color: #666;
  line-height: 1.6;
  margin-bottom: 16px;
  font-size: 1.1rem;
}

.phone-contact .phone-number {
  margin-bottom: 20px;
}

.phone-contact .phone-number .tel-label {
  display: block;
  font-size: 1.05rem;
  color: #666;
  margin-bottom: 8px;
  font-weight: 500;
}

.phone-contact .phone-number .tel-number {
  display: block;
  font-size: 2rem;
  font-weight: 700;
  color: #007cba;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.phone-contact .phone-number .tel-number:hover {
  color: #005a87;
}

.phone-contact .business-hours p {
  margin-bottom: 8px;
  font-size: 1.1rem;
}

.phone-contact .business-hours p:last-child {
  margin-bottom: 0;
}

.office-info .office-details h4 {
  font-size: 1.1rem;
  font-weight: 600;
  color: #333;
  margin-bottom: 16px;
}

.office-info .office-details .address {
  color: #666;
  line-height: 1.6;
  margin-bottom: 12px;
  font-size: 1.1rem;
}

.office-info .office-details .fax {
  color: #666;
  font-size: 1.1rem;
  margin-bottom: 0;
}

/* Form Enhancements */
.form-container .wpcf7-form .wpcf7-form-control-wrap {
  display: block;
  margin-bottom: 20px;
}

.form-container .wpcf7-form .wpcf7-form-control {
  margin-bottom: 0;
}

.form-container .wpcf7-form .wpcf7-submit {
  width: auto;
  margin: 20px auto 0;
  font-size: 1.25rem;
  padding: 18px 40px;
  display: block;
}

/* General form submit button centering */
.form-container form p:last-child {
  text-align: center;
}

.form-container input[type=submit] {
  width: auto;
  margin: 20px auto 0;
  padding: 18px 40px;
  display: block;
}

/* Contact Form 7 送信ボタンの中央寄せを強化 */
.contact-section .wpcf7-form p:last-of-type,
.contact-section .wpcf7-form .wpcf7-submit-wrap,
.form-container .wpcf7-form p:has(.wpcf7-submit),
.form-container .wpcf7-form p.wpcf7-form-submit {
  text-align: center !important;
  margin-bottom: 0;
}

.contact-section .wpcf7-submit,
.form-container .wpcf7-submit {
  width: auto !important;
  margin: 20px auto 0 !important;
  padding: 18px 40px !important;
  display: block !important;
}

/* Simple Contact Page Styles - シンプルなお問い合わせページ */
.contact-section-simple {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
}

.contact-container-simple {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 40px 400px;
  grid-template-columns: 1fr 400px;
  gap: 40px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}

@media (max-width: 768px) {
  .contact-container-simple {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
.contact-form-wrapper-simple .form-container-simple {
  background: transparent;
  padding: 0;
  border-radius: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  border: none;
}

.contact-info-wrapper-simple {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 30px;
}

.contact-method-simple {
  background: transparent;
  padding: 20px 0;
  border-radius: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  border: none;
  border-bottom: 1px solid #eee;
}

.contact-method-simple:last-child {
  border-bottom: none;
}

.contact-method-simple p {
  margin-bottom: 10px;
  font-size: 1.1rem;
}

.contact-method-simple .phone-info,
.contact-method-simple .office-details {
  margin-top: 10px;
}

.contact-method-simple .phone-number {
  margin-bottom: 10px;
}

.contact-method-simple .phone-number .tel-label {
  font-weight: 600;
  margin-right: 8px;
  color: #333;
}

.contact-method-simple .phone-number .tel-number {
  font-size: 1.25rem;
  font-weight: 600;
  color: #007cba;
  text-decoration: none;
}

.contact-method-simple .phone-number .tel-number:hover {
  color: #005a87;
  text-decoration: underline;
}

.contact-method-simple .business-hours p,
.contact-method-simple .office-details p {
  margin-bottom: 5px;
  color: #666;
  font-size: 1rem;
}

/* シンプル版の送信ボタンスタイル */
.contact-section-simple .wpcf7-form p:last-of-type,
.contact-section-simple .wpcf7-form .wpcf7-submit-wrap,
.form-container-simple .wpcf7-form p:has(.wpcf7-submit),
.form-container-simple .wpcf7-form p.wpcf7-form-submit {
  text-align: center !important;
  margin-bottom: 0;
}

.contact-section-simple .wpcf7-submit,
.form-container-simple .wpcf7-submit {
  width: auto !important;
  margin: 20px auto 0 !important;
  padding: 18px 40px !important;
  display: block !important;
}

/*--------------------------------------------------------------
11.0 Featured Image Hover
--------------------------------------------------------------*/
.post-thumbnail {
  margin-bottom: 1em;
}

.post-thumbnail a img {
  -webkit-backface-visibility: hidden;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}

.post-thumbnail a:hover img,
.post-thumbnail a:focus img {
  opacity: 0.7;
}

/*--------------------------------------------------------------
13.4 Posts
--------------------------------------------------------------*/
/* Post Landing Page */
.sticky {
  position: relative;
}

.post:not(.sticky) .icon-thumb-tack {
  display: none;
}

.sticky .icon-thumb-tack {
  display: block;
  height: 18px;
  left: -1.5em;
  position: absolute;
  top: 1.65em;
  width: 20px;
}

.entry-header .entry-title {
  margin-bottom: 0.25em;
}

.entry-title a {
  color: #333;
  text-decoration: none;
  margin-left: -2px;
}

.entry-title:not(:first-child) {
  padding-top: 0;
}

.entry-meta {
  color: #767676;
  font-size: 11px;
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.1818em;
  padding-bottom: 0.25em;
  text-transform: uppercase;
}

.entry-meta a {
  color: #767676;
}

.byline,
.updated:not(.published) {
  display: none;
}

.single .byline,
.group-blog .byline {
  display: inline;
}

.pagination,
.comments-pagination {
  border-top: 1px solid #eee;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 800;
  padding: 2em 0 3em;
  text-align: center;
}

.pagination .icon,
.comments-pagination .icon {
  width: 0.666666666em;
  height: 0.666666666em;
}

.comments-pagination {
  border: 0;
}

.page-numbers {
  display: none;
  padding: 0.5em 0.75em;
}

.page-numbers.current {
  color: #767676;
  display: inline-block;
}

.page-numbers.current .screen-reader-text {
  clip: auto;
  height: auto;
  overflow: auto;
  position: relative !important;
  width: auto;
}

.prev.page-numbers,
.next.page-numbers {
  background-color: #ddd;
  border-radius: 2px;
  display: inline-block;
  font-size: 24px;
  font-size: 1.5rem;
  line-height: 1;
  padding: 0.25em 0.5em 0.4em;
}

.prev.page-numbers,
.next.page-numbers {
  -webkit-transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.3s ease-in-out;
  transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.3s ease-in-out;
}

.prev.page-numbers:focus,
.prev.page-numbers:hover,
.next.page-numbers:focus,
.next.page-numbers:hover {
  background-color: #767676;
  color: #fff;
}

.prev.page-numbers {
  float: left;
}

.next.page-numbers {
  float: right;
}

/* Aligned blockquotes */
.entry-content blockquote.alignleft,
.entry-content blockquote.alignright {
  color: #666;
  font-size: 13px;
  font-size: 0.8125rem;
  width: 48%;
}

/* Blog landing, search, archives */
.blog .site-main > article,
.archive .site-main > article,
.search .site-main > article {
  padding-bottom: 2em;
}

.blog .entry-meta a.post-edit-link,
.archive .entry-meta a.post-edit-link,
.search .entry-meta a.post-edit-link {
  color: #222;
  display: inline-block;
  margin-left: 1em;
  white-space: nowrap;
}

.search .page .entry-meta a.post-edit-link {
  margin-left: 0;
  white-space: nowrap;
}

.taxonomy-description {
  color: #666;
  font-size: 13px;
  font-size: 0.8125rem;
}

/* More tag */
.entry-content .more-link:before {
  content: "";
  display: block;
  margin-top: 1.5em;
}

/* Single Post */
.single-post:not(.has-sidebar) #primary,
.page.page-one-column:not(.twentyseventeen-front-page) #primary,
.archive.page-one-column:not(.has-sidebar) .page-header,
.archive.page-one-column:not(.has-sidebar) #primary {
  margin-left: auto;
  margin-right: auto;
  max-width: 740px;
}

.single-featured-image-header {
  background-color: #fafafa;
  border-bottom: 1px solid #eee;
}

.single-featured-image-header img {
  display: block;
  margin: auto;
}

.page-links {
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 800;
  padding: 2em 0 3em;
}

.page-links .page-number {
  color: #767676;
  display: inline-block;
  padding: 0.5em 1em;
}

.page-links a {
  display: inline-block;
}

.page-links a .page-number {
  color: #222;
}

/* Entry footer */
.entry-footer {
  border-bottom: 1px solid #eee;
  border-top: 1px solid #eee;
  margin-top: 2em;
  padding: 2em 0;
}

.entry-footer .cat-links,
.entry-footer .tags-links {
  display: block;
  font-size: 11px;
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.1818em;
  padding-left: 2.5em;
  position: relative;
  text-transform: uppercase;
}

.entry-footer .cat-links + .tags-links {
  margin-top: 1em;
}

.entry-footer .cat-links a,
.entry-footer .tags-links a {
  color: #333;
}

.entry-footer .cat-links .icon,
.entry-footer .tags-links .icon {
  color: #767676;
  left: 0;
  margin-right: 0.5em;
  position: absolute;
  top: 2px;
}

.entry-footer .edit-link {
  display: inline-block;
}

.entry-footer .edit-link a.post-edit-link {
  background-color: #222;
  border-radius: 2px;
  -webkit-box-shadow: none;
  box-shadow: none;
  color: #fff;
  display: inline-block;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 800;
  margin-top: 2em;
  padding: 0.7em 2em;
  -webkit-transition: background-color 0.2s ease-in-out;
  transition: background-color 0.2s ease-in-out;
  white-space: nowrap;
}

.entry-footer .edit-link a.post-edit-link:hover,
.entry-footer .edit-link a.post-edit-link:focus {
  background-color: #767676;
}

/* Post Formats */
.blog .format-status .entry-title,
.archive .format-status .entry-title,
.blog .format-aside .entry-title,
.archive .format-aside .entry-title {
  display: none;
}

.format-quote blockquote {
  color: #333;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 300;
  overflow: visible;
  position: relative;
}

.format-quote blockquote .icon {
  display: block;
  height: 20px;
  left: -1.25em;
  position: absolute;
  top: 0.4em;
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1);
  width: 20px;
}

/* Post Navigation */
.post-navigation {
  font-weight: 800;
  margin: 3em 0;
}

.post-navigation .nav-links {
  padding: 1em 0;
}

.nav-subtitle {
  background: transparent;
  color: #767676;
  display: block;
  font-size: 11px;
  font-size: 0.6875rem;
  letter-spacing: 0.1818em;
  margin-bottom: 1em;
  text-transform: uppercase;
}

.nav-title {
  color: #333;
  font-size: 15px;
  font-size: 0.9375rem;
}

.post-navigation .nav-next {
  margin-top: 1.5em;
}

.nav-links .nav-previous .nav-title .nav-title-icon-wrapper {
  margin-right: 0.5em;
}

.nav-links .nav-next .nav-title .nav-title-icon-wrapper {
  margin-left: 0.5em;
}

/*--------------------------------------------------------------
13.5 Pages
--------------------------------------------------------------*/
/* 404 page */
.error404 .page-content {
  padding-bottom: 4em;
}

.error404 .page-content .search-form,
.search .page-content .search-form {
  margin-bottom: 3em;
}

/*--------------------------------------------------------------
15.0 Widgets
--------------------------------------------------------------*/
#secondary {
  padding: 1em 0 2em;
}

/* widget forms */
.widget select {
  width: 100%;
}

/* widget lists */
.widget ul {
  list-style: none;
  margin: 0;
}

.widget ul li,
.widget ol li {
  border-bottom: 1px solid #ddd;
  border-top: 1px solid #ddd;
  padding: 0.5em 0;
}

.widget:not(.widget_tag_cloud) ul li + li {
  margin-top: -1px;
}

.widget ul li ul {
  margin: 0 0 -1px;
  padding: 0;
  position: relative;
}

.widget ul li li {
  border: 0;
  padding-left: 24px;
  padding-left: 1.5rem;
}

/* Widget lists of links */
.widget_top-posts ul li ul,
.widget_rss_links ul li ul,
.widget-grofile ul.grofile-links li ul,
.widget_pages ul li ul,
.widget_meta ul li ul {
  bottom: 0;
}

.widget_nav_menu ul li li,
.widget_top-posts ul li,
.widget_top-posts ul li li,
.widget_rss_links ul li,
.widget_rss_links ul li li,
.widget-grofile ul.grofile-links li,
.widget-grofile ul.grofile-links li li {
  padding-bottom: 0.25em;
  padding-top: 0.25em;
}

.widget_rss ul li {
  padding-bottom: 1em;
  padding-top: 1em;
}

/* Widget markup */
.widget .post-date,
.widget .rss-date {
  font-size: 0.81em;
}

/* Text widget */
.widget_text {
  word-wrap: break-word;
}

.widget_text ul {
  list-style: disc;
  margin: 0 0 1.5em 1.5em;
}

.widget_text ol {
  list-style: decimal;
}

.widget_text ul li,
.widget_text ol li {
  border: none;
}

.widget_text ul li:last-child,
.widget_text ol li:last-child {
  padding-bottom: 0;
}

.widget_text ul li ul {
  margin: 0 0 0 1.5em;
}

.widget_text ul li li {
  padding-left: 0;
  padding-right: 0;
}

.widget_text ol li {
  list-style-position: inside;
}

.widget_text ol li + li {
  margin-top: -1px;
}

/* RSS Widget */
.widget_rss .widget-title .rsswidget:first-child {
  float: right;
}

.widget_rss .widget-title .rsswidget:first-child:hover {
  background-color: transparent;
}

.widget_rss .widget-title .rsswidget:first-child img {
  display: block;
}

.widget_rss ul li {
  padding: 2.125em 0;
}

.widget_rss ul li:first-child {
  border-top: none;
  padding-top: 0;
}

.widget_rss li .rsswidget {
  font-size: 22px;
  font-size: 1.375rem;
  font-weight: 300;
  line-height: 1.4;
}

.widget_rss .rss-date,
.widget_rss li cite {
  color: #767676;
  display: block;
  font-size: 10px;
  font-size: 0.625rem;
  font-style: normal;
  font-weight: 800;
  letter-spacing: 0.18em;
  line-height: 1.5;
  text-transform: uppercase;
}

.widget_rss .rss-date {
  margin: 0.5em 0 1.5em;
  padding: 0;
}

.widget_rss .rssSummary {
  margin-bottom: 0.5em;
}

/* Contact Info Widget */
.widget_contact_info .contact-map {
  margin-bottom: 0.5em;
}

/* Gravatar */
.widget-grofile h4 {
  font-size: 16px;
  font-size: 1rem;
  margin-bottom: 0;
}

/* Recent Comments */
.widget_recent_comments table,
.widget_recent_comments th,
.widget_recent_comments td {
  border: 0;
}

/* Recent Posts widget */
.widget_recent_entries .post-date {
  display: block;
}

/* Search */
.search-form {
  position: relative;
}

.search-form .search-submit {
  bottom: 3px;
  padding: 0.5em 1em;
  position: absolute;
  right: 3px;
  top: 3px;
}

.search-form .search-submit .icon {
  height: 24px;
  top: -2px;
  width: 24px;
}

/* Tag cloud widget */
.tagcloud ul li {
  float: left;
  border-top: 0;
  border-bottom: 0;
  padding: 0;
  margin: 4px 4px 0 0;
}

.tagcloud,
.widget_tag_cloud,
.wp_widget_tag_cloud {
  line-height: 1.5;
}

.widget .tagcloud a,
.widget.widget_tag_cloud a,
.wp_widget_tag_cloud a {
  border: 1px solid #ddd;
  -webkit-box-shadow: none;
  box-shadow: none;
  display: block;
  padding: 4px 10px 5px;
  position: relative;
  -webkit-transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.3s ease-in-out;
  transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.3s ease-in-out;
  width: auto;
  word-wrap: break-word;
  z-index: 0;
}

.widget .tagcloud a:hover,
.widget .tagcloud a:focus,
.widget.widget_tag_cloud a:hover,
.widget.widget_tag_cloud a:focus,
.wp_widget_tag_cloud a:hover,
.wp_widget_tag_cloud a:focus {
  border-color: #bbb;
  -webkit-box-shadow: none;
  box-shadow: none;
  text-decoration: none;
}

/* Calendar widget */
.widget_calendar .wp-calendar-table {
  margin-bottom: 0;
}

.widget_calendar .wp-calendar-nav {
  display: table;
  width: 100%;
  margin: 0 0 1.5em;
  padding: 0.4em 0;
}

.widget_calendar .wp-calendar-nav span {
  display: table-cell;
}

.widget_calendar .wp-calendar-nav-prev,
.widget_calendar .wp-calendar-nav-next {
  width: 40%;
}

.widget_calendar th,
.widget_calendar td,
.widget_calendar .wp-calendar-nav span {
  text-align: center;
}

.widget_calendar tfoot td {
  border: 0;
}

/* Gallery widget */
.gallery-columns-5 .gallery-caption,
.gallery-columns-6 .gallery-caption,
.gallery-columns-7 .gallery-caption,
.gallery-columns-8 .gallery-caption,
.gallery-columns-9 .gallery-caption {
  display: none;
}

/*--------------------------------------------------------------
16.0 Media
--------------------------------------------------------------*/
/* SVG Icons base styles */
/*--------------------------------------------------------------
16.1 Galleries
--------------------------------------------------------------*/
.gallery-item {
  display: inline-block;
  text-align: left;
  vertical-align: top;
  margin: 0 0 1.5em;
  padding: 0 1em 0 0;
  width: 50%;
}

.gallery-columns-1 .gallery-item {
  width: 100%;
}

.gallery-columns-2 .gallery-item {
  max-width: 50%;
}

.gallery-item a,
.gallery-item a:hover,
.gallery-item a:focus,
.widget-area .gallery-item a,
.widget-area .gallery-item a:hover,
.widget-area .gallery-item a:focus {
  -webkit-box-shadow: none;
  box-shadow: none;
  background: none;
  display: inline-block;
  max-width: 100%;
}

.gallery-item a img {
  display: block;
  -webkit-transition: -webkit-filter 0.2s ease-in;
  transition: -webkit-filter 0.2s ease-in;
  transition: filter 0.2s ease-in;
  transition: filter 0.2s ease-in, -webkit-filter 0.2s ease-in;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.gallery-item a:hover img,
.gallery-item a:focus img {
  -webkit-filter: opacity(60%);
  filter: opacity(60%);
}

.gallery-caption {
  display: block;
  text-align: left;
  padding: 0 10px 0 0;
  margin-bottom: 0;
}

/*--------------------------------------------------------------
18.0 SVGs Fallbacks
--------------------------------------------------------------*/
.svg-fallback {
  display: none;
}

.no-svg .svg-fallback {
  display: inline-block;
}

.no-svg .dropdown-toggle {
  padding: 0.5em 0 0;
  right: 0;
  text-align: center;
  width: 2em;
}

.no-svg .dropdown-toggle .svg-fallback.icon-angle-down {
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1;
  -webkit-transform: rotate(180deg); /* Chrome, Safari, Opera */ /* IE 9 */
  transform: rotate(180deg);
}

.no-svg .dropdown-toggle.toggled-on .svg-fallback.icon-angle-down {
  -webkit-transform: rotate(0); /* Chrome, Safari, Opera */ /* IE 9 */
  transform: rotate(0);
}

.no-svg .dropdown-toggle .svg-fallback.icon-angle-down:before {
  content: "^";
}

/* Social Menu fallbacks */
.no-svg .social-navigation a {
  background: transparent;
  color: #222;
  height: auto;
  width: auto;
}

/* Show screen reader text in some cases */
.no-svg .next.page-numbers .screen-reader-text,
.no-svg .prev.page-numbers .screen-reader-text,
.no-svg .social-navigation li a .screen-reader-text,
.no-svg .search-submit .screen-reader-text {
  clip: auto;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 400;
  height: auto;
  position: relative !important; /* overrides previous !important styles */
  width: auto;
}

/*--------------------------------------------------------------
19.0 Media Queries
--------------------------------------------------------------*/
@media screen and (min-width: 48em) {
  /* Layout */
  .wrap {
    max-width: 1000px;
    padding-left: 3em;
    padding-right: 3em;
  }
  .has-sidebar:not(.error404) #primary {
    float: left;
    width: 58%;
  }
  .error404 #primary {
    float: none;
  }
  /* Site Branding */
  .site-branding {
    margin-bottom: 0;
  }
  .has-header-image.twentyseventeen-front-page .site-branding,
  .has-header-video.twentyseventeen-front-page .site-branding,
  .has-header-image.home.blog .site-branding,
  .has-header-video.home.blog .site-branding {
    bottom: 0;
    display: block;
    left: 0;
    height: auto;
    padding-top: 0;
    position: absolute;
    width: 100%;
  }
  .has-header-image.twentyseventeen-front-page .custom-header,
  .has-header-video.twentyseventeen-front-page .custom-header,
  .has-header-image.home.blog .custom-header,
  .has-header-video.home.blog .custom-header {
    display: block;
    height: auto;
  }
  .custom-header-media {
    height: 165px;
    position: relative;
  }
  .twentyseventeen-front-page.has-header-image .custom-header-media,
  .twentyseventeen-front-page.has-header-video .custom-header-media,
  .home.blog.has-header-image .custom-header-media,
  .home.blog.has-header-video .custom-header-media {
    height: 0;
    position: relative;
  }
  .has-header-image:not(.twentyseventeen-front-page):not(.home) .custom-header-media,
  .has-header-video:not(.twentyseventeen-front-page):not(.home) .custom-header-media {
    bottom: 0;
    height: auto;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
  }
  .custom-logo-link {
    padding-right: 2em;
  }
  .custom-logo-link img,
  body.home.title-tagline-hidden.has-header-image .custom-logo-link img,
  body.home.title-tagline-hidden.has-header-video .custom-logo-link img {
    max-width: 350px;
  }
  .title-tagline-hidden.home.has-header-image .custom-logo-link img,
  .title-tagline-hidden.home.has-header-video .custom-logo-link img {
    max-height: 200px;
  }
  /* Navigation */
  .navigation-top {
    bottom: 0;
    font-size: 14px;
    font-size: 0.875rem;
    left: 0;
    position: absolute;
    right: 0;
    width: 100%;
    z-index: 3;
  }
  .navigation-top .wrap {
    max-width: 1000px;
    /* The font size is 14px here and we need 50px padding in ems */
    padding: 0.75em 3.4166666667em;
  }
  .navigation-top nav {
    margin-left: -1.25em;
  }
  .site-navigation-fixed.navigation-top {
    bottom: auto;
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 7;
  }
  .admin-bar .site-navigation-fixed.navigation-top {
    top: 32px;
  }
  /* Main Navigation */
  .js .menu-toggle,
  .js .dropdown-toggle {
    display: none;
  }
  .main-navigation {
    width: auto;
  }
  .js .main-navigation ul,
  .js .main-navigation ul ul,
  .js .main-navigation > div > ul {
    display: block;
  }
  .main-navigation ul {
    background: transparent;
    padding: 0;
  }
  .main-navigation > div > ul {
    border: 0;
    margin-bottom: 0;
    padding: 0;
  }
  .main-navigation li {
    border: 0;
    display: inline-block;
  }
  .main-navigation li li {
    display: block;
  }
  .main-navigation a {
    padding: 1em 1.25em;
  }
  .main-navigation ul ul {
    background: #fff;
    border: 1px solid #bbb;
    left: -999em;
    padding: 0;
    position: absolute;
    top: 100%;
    z-index: 99999;
  }
  .main-navigation ul li.menu-item-has-children:before,
  .main-navigation ul li.menu-item-has-children:after,
  .main-navigation ul li.page_item_has_children:before,
  .main-navigation ul li.page_item_has_children:after {
    border-style: solid;
    border-width: 0 6px 6px;
    content: "";
    display: none;
    height: 0;
    position: absolute;
    right: 1em;
    bottom: -1px;
    width: 0;
    z-index: 100000;
  }
  .main-navigation ul li.menu-item-has-children.focus:before,
  .main-navigation ul li.menu-item-has-children:hover:before,
  .main-navigation ul li.menu-item-has-children.focus:after,
  .main-navigation ul li.menu-item-has-children:hover:after,
  .main-navigation ul li.page_item_has_children.focus:before,
  .main-navigation ul li.page_item_has_children:hover:before,
  .main-navigation ul li.page_item_has_children.focus:after,
  .main-navigation ul li.page_item_has_children:hover:after {
    display: block;
  }
  .main-navigation ul li.menu-item-has-children:before,
  .main-navigation ul li.page_item_has_children:before {
    border-color: transparent transparent #bbb;
    bottom: 0;
  }
  .main-navigation ul li.menu-item-has-children:after,
  .main-navigation ul li.page_item_has_children:after {
    border-color: transparent transparent #fff;
  }
  .main-navigation ul ul li:hover > ul,
  .main-navigation ul ul li.focus > ul {
    left: 100%;
    right: auto;
  }
  .main-navigation ul ul a {
    padding: 0.75em 1.25em;
    width: 16em;
  }
  .main-navigation li li {
    -webkit-transition: background-color 0.2s ease-in-out;
    transition: background-color 0.2s ease-in-out;
  }
  .main-navigation li li:hover,
  .main-navigation li li.focus {
    background: #767676;
  }
  .main-navigation li li a {
    -webkit-transition: color 0.3s ease-in-out;
    transition: color 0.3s ease-in-out;
  }
  .main-navigation li li.focus > a,
  .main-navigation li li:focus > a,
  .main-navigation li li:hover > a,
  .main-navigation li li a:hover,
  .main-navigation li li a:focus,
  .main-navigation li li.current_page_item a:hover,
  .main-navigation li li.current-menu-item a:hover,
  .main-navigation li li.current_page_item a:focus,
  .main-navigation li li.current-menu-item a:focus {
    color: #fff;
  }
  .main-navigation ul li:hover > ul,
  .main-navigation ul li.focus > ul {
    left: 0.5em;
    right: auto;
  }
  .main-navigation .menu-item-has-children > a > .icon,
  .main-navigation .page_item_has_children > a > .icon {
    display: inline;
    left: 5px;
    position: relative;
    top: -1px;
  }
  .main-navigation ul ul .menu-item-has-children > a > .icon,
  .main-navigation ul ul .page_item_has_children > a > .icon {
    margin-top: -9px;
    left: auto;
    position: absolute;
    right: 1em;
    top: 50%;
    -webkit-transform: rotate(-90deg); /* Chrome, Safari, Opera */ /* IE 9 */
    transform: rotate(-90deg);
  }
  .main-navigation ul ul ul {
    left: -999em;
    margin-top: -1px;
    top: 0;
  }
  .main-navigation ul ul li.menu-item-has-children.focus:before,
  .main-navigation ul ul li.menu-item-has-children:hover:before,
  .main-navigation ul ul li.menu-item-has-children.focus:after,
  .main-navigation ul ul li.menu-item-has-children:hover:after,
  .main-navigation ul ul li.page_item_has_children.focus:before,
  .main-navigation ul ul li.page_item_has_children:hover:before,
  .main-navigation ul ul li.page_item_has_children.focus:after,
  .main-navigation ul ul li.page_item_has_children:hover:after {
    display: none;
  }
  .site-header .site-navigation-fixed .menu-scroll-down {
    display: none;
  }
  /* Scroll down arrow */
  .site-header .menu-scroll-down {
    display: block;
    padding: 1em;
    position: absolute;
    right: 0;
  }
  .site-header .menu-scroll-down .icon {
    -webkit-transform: rotate(90deg); /* Chrome, Safari, Opera */ /* IE 9 */
    transform: rotate(90deg);
  }
  .site-header .menu-scroll-down {
    color: #fff;
    top: 2em;
  }
  .site-header .navigation-top .menu-scroll-down {
    color: #767676;
    top: 0.7em;
  }
  .menu-scroll-down:focus {
    outline: thin dotted;
  }
  .menu-scroll-down .icon {
    height: 18px;
    width: 18px;
  }
  /* Front Page */
  .twentyseventeen-front-page.has-header-image .site-branding,
  .twentyseventeen-front-page.has-header-video .site-branding,
  .home.blog.has-header-image .site-branding,
  .home.blog.has-header-video .site-branding {
    margin-bottom: 70px;
  }
  .twentyseventeen-front-page.has-header-image .custom-header-media,
  .twentyseventeen-front-page.has-header-video .custom-header-media,
  .home.blog.has-header-image .custom-header-media,
  .home.blog.has-header-video .custom-header-media {
    height: 1200px;
    height: 100vh;
    max-height: 100%;
    overflow: hidden;
  }
  .twentyseventeen-front-page.has-header-image .custom-header-media:before,
  .twentyseventeen-front-page.has-header-video .custom-header-media:before,
  .home.blog.has-header-image .custom-header-media:before,
  .home.blog.has-header-video .custom-header-media:before {
    height: 33%;
  }
  .admin-bar.twentyseventeen-front-page.has-header-image .custom-header-media,
  .admin-bar.twentyseventeen-front-page.has-header-video .custom-header-media,
  .admin-bar.home.blog.has-header-image .custom-header-media,
  .admin-bar.home.blog.has-header-video .custom-header-media {
    height: calc(100vh - 32px);
  }
  .panel-content .wrap {
    padding-bottom: 4.5em;
    padding-top: 6em;
  }
  .panel-image {
    height: 100vh;
    max-height: 1200px;
  }
  /* With panel images 100% of the screen height, we're going to fix the background image where supported to create a parallax-like effect. */
  .background-fixed .panel-image {
    background-attachment: fixed;
  }
  .page-two-column .panel-content .entry-header {
    float: left;
    width: 36%;
  }
  .page-two-column .panel-content .entry-content {
    float: right;
    width: 58%;
  }
  /* Front Page - Recent Posts */
  .page-two-column .panel-content .recent-posts {
    clear: right;
    float: right;
    width: 58%;
  }
  .panel-content .recent-posts article {
    margin-bottom: 4em;
  }
  .panel-content .recent-posts .entry-header,
  .page-two-column #primary .panel-content .recent-posts .entry-header,
  .panel-content .recent-posts .entry-content,
  .page-two-column #primary .panel-content .recent-posts .entry-content {
    float: none;
    width: 100%;
  }
  .panel-content .recent-posts .entry-header {
    margin-bottom: 1.5em;
  }
  .page .panel-content .recent-posts .entry-title {
    font-size: 26px;
    font-size: 1.625rem;
  }
  /* Posts */
  .site-content {
    padding: 5.5em 0 0;
  }
  .single-post .entry-title,
  .page .entry-title {
    font-size: 26px;
    font-size: 1.625rem;
  }
  .comments-pagination,
  .post-navigation {
    clear: both;
  }
  .post-navigation .nav-previous {
    float: left;
    width: 50%;
  }
  .post-navigation .nav-next {
    float: right;
    text-align: right;
    width: 50%;
  }
  .nav-next,
  .post-navigation .nav-next {
    margin-top: 0;
  }
  /* Blog, archive, search */
  .sticky .icon-thumb-tack {
    height: 23px;
    left: -2.5em;
    top: 1.5em;
    width: 32px;
  }
  .blog .site-main > article,
  .archive .site-main > article,
  .search .site-main > article {
    padding-bottom: 4em;
  }
  .navigation.pagination {
    clear: both;
    float: right;
    width: 58%;
    position: relative;
  }
  .has-sidebar .navigation.pagination,
  .archive.page-one-column:not(.has-sidebar) .navigation.pagination {
    float: none;
    width: 100%;
  }
  .entry-footer {
    display: table;
    width: 100%;
  }
  .entry-footer .cat-tags-links {
    display: table-cell;
    vertical-align: middle;
    width: 100%;
  }
  .entry-footer .edit-link {
    display: table-cell;
    text-align: right;
    vertical-align: middle;
  }
  .entry-footer .edit-link a.post-edit-link {
    margin-top: 0;
    margin-left: 1em;
  }
  /* Entry content */
  /* without sidebar */
  :not(.has-sidebar) .entry-content blockquote.alignleft {
    margin-left: -17.5%;
    width: 48%;
  }
  :not(.has-sidebar) .entry-content blockquote.alignright {
    margin-right: -17.5%;
    width: 48%;
  }
  /* with sidebar */
  .has-sidebar .entry-content blockquote.alignleft {
    margin-left: 0;
    width: 34%;
  }
  .has-sidebar .entry-content blockquote.alignright {
    margin-right: 0;
    width: 34%;
  }
  .has-sidebar #primary .entry-content blockquote.alignright.below-entry-meta {
    margin-right: -72.5%;
    width: 62%;
  }
  /* blog and archive */
  .blog:not(.has-sidebar) .entry-content blockquote.alignleft,
  .twentyseventeen-front-page.page-two-column .entry-content blockquote.alignleft,
  .archive:not(.has-sidebar) .entry-content blockquote.alignleft,
  .page-two-column .entry-content blockquote.alignleft {
    margin-left: -72.5%;
    width: 62%;
  }
  .blog:not(.has-sidebar) .entry-content blockquote.alignright,
  .twentyseventeen-front-page.page-two-column .entry-content blockquote.alignright,
  .archive:not(.has-sidebar) .entry-content blockquote.alignright,
  .page-two-column .entry-content blockquote.alignright {
    margin-right: 0;
    width: 36%;
  }
  /* Post formats */
  .format-quote blockquote .icon {
    left: -1.5em;
  }
  /* Pages */
  .page.page-one-column .entry-header,
  .twentyseventeen-front-page.page-one-column .entry-header,
  .archive.page-one-column:not(.has-sidebar) .page-header {
    margin-bottom: 4em;
  }
  .page:not(.home) #content {
    padding-bottom: 3.25em;
  }
  /* 404 page */
  .error404 .page-content {
    padding-bottom: 9em;
  }
  /* Gallery Columns */
  .gallery-columns-5 .gallery-item {
    max-width: 20%;
  }
  .gallery-columns-6 .gallery-item {
    max-width: 16.66%;
  }
  .gallery-columns-7 .gallery-item {
    max-width: 14.28%;
  }
  .gallery-columns-8 .gallery-item {
    max-width: 12.5%;
  }
  .gallery-columns-9 .gallery-item {
    max-width: 11.11%;
  }
}
@media screen and (min-width: 67em) {
  /* Sticky posts */
  .sticky .icon-thumb-tack {
    font-size: 32px;
    font-size: 2rem;
    height: 22px;
    left: -1.25em;
    top: 0.75em;
    width: 32px;
  }
  /* Pagination */
  .page-numbers {
    display: inline-block;
  }
  .page-numbers.current {
    font-size: 15px;
    font-size: 0.9375rem;
  }
  .page-numbers.current .screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    overflow: hidden;
    position: absolute !important;
    width: 1px;
  }
}
/* ハンバーガーメニューのスタイル */
.navbar-toggler {
  background: #ffffff !important;
  background-color: #ffffff !important;
  background-image: none !important;
  border: 1px solid #dee2e6 !important;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
  padding: 4px 8px !important;
}

.navbar-toggler:focus {
  background: #ffffff !important;
  background-color: #ffffff !important;
  background-image: none !important;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
  outline: none !important;
}

.navbar-toggler:hover {
  background: #f8f9fa !important;
  background-color: #f8f9fa !important;
  background-image: none !important;
}

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
1.0 Normalize
2.0 Accessibility
3.0 Alignments
4.0 Clearings
5.0 Typography
6.0 Forms
7.0 Formatting
8.0 Lists
9.0 Tables
10.0 Links
11.0 Featured Image Hover
12.0 Navigation
13.0 Layout
   13.1 Header
   13.2 Front Page
   13.3 Regular Content
   13.4 Posts
   13.5 Pages
   13.6 Footer
14.0 Comments
15.0 Widgets
16.0 Media
   16.1 Galleries
17.0 Customizer
18.0 SVGs Fallbacks
19.0 Media Queries
20.0 Print
--------------------------------------------------------------*/
/*--------------------------------------------------------------
1.0 Normalize
Styles based on Normalize v5.0.0 @link https://github.com/necolas/normalize.css
--------------------------------------------------------------*/
svg:not(:root) {
  overflow: hidden;
}

button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

[type=checkbox],
[type=radio] {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

/*--------------------------------------------------------------
2.0 Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers. */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  overflow: hidden;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important; /* Many screen reader and browser combinations announce broken words as they would appear visually. */
}

.screen-reader-text:focus {
  background-color: #f1f1f1;
  border-radius: 3px;
  -webkit-box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  color: #21759b;
  display: block;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 700;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000; /* Above WP toolbar. */
}

/*--------------------------------------------------------------
4.0 Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.entry-footer:before,
.entry-footer:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after,
.nav-links:before,
.nav-links:after,
.pagination:before,
.pagination:after,
.comment-author:before,
.comment-author:after,
.widget-area:before,
.widget-area:after,
.widget:before,
.widget:after,
.comment-meta:before,
.comment-meta:after {
  content: "";
  display: table;
  table-layout: fixed;
}

.clear:after,
.entry-content:after,
.entry-footer:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after,
.nav-links:after,
.pagination:after,
.comment-author:after,
.widget-area:after,
.widget:after,
.comment-meta:after {
  clear: both;
}

/*--------------------------------------------------------------
5.0 Typography
--------------------------------------------------------------*/
/*--------------------------------------------------------------
5.5 Typography Overrides
--------------------------------------------------------------*/
/* General paragraph styling */
p {
  font-size: 1.3rem;
  line-height: 1.6;
}

/* General table styling */
table {
  font-size: 1.3rem;
}

/* General ul, ol styling */
ul, ol {
  font-size: 1.3rem;
}

ul li, ol li {
  font-size: 1.3rem;
}

/*--------------------------------------------------------------
6.0 Forms
--------------------------------------------------------------*/
/* Form Labels */
label {
  color: #333;
  display: block;
  font-weight: 600;
  margin-bottom: 0.5em;
  font-size: 1.1rem;
  letter-spacing: 0.5px;
}

fieldset {
  margin-bottom: 1.5em;
  border: none;
  padding: 0;
}

/* Modern Form Inputs */
input[type=text],
input[type=email],
input[type=url],
input[type=password],
input[type=search],
input[type=number],
input[type=tel],
input[type=range],
input[type=date],
input[type=month],
input[type=week],
input[type=time],
input[type=datetime],
input[type=datetime-local],
input[type=color],
textarea {
  color: #333;
  background: #fff;
  border: 2px solid #e1e5e9;
  border-radius: 8px;
  display: block;
  padding: 12px 16px;
  width: 100%;
  font-size: 18px;
  line-height: 1.5;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

input[type=text]::-webkit-input-placeholder, input[type=email]::-webkit-input-placeholder, input[type=url]::-webkit-input-placeholder, input[type=password]::-webkit-input-placeholder, input[type=search]::-webkit-input-placeholder, input[type=number]::-webkit-input-placeholder, input[type=tel]::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #8a8a8a;
  font-style: italic;
}

input[type=text]::-moz-placeholder, input[type=email]::-moz-placeholder, input[type=url]::-moz-placeholder, input[type=password]::-moz-placeholder, input[type=search]::-moz-placeholder, input[type=number]::-moz-placeholder, input[type=tel]::-moz-placeholder, textarea::-moz-placeholder {
  color: #8a8a8a;
  font-style: italic;
}

input[type=text]:-ms-input-placeholder, input[type=email]:-ms-input-placeholder, input[type=url]:-ms-input-placeholder, input[type=password]:-ms-input-placeholder, input[type=search]:-ms-input-placeholder, input[type=number]:-ms-input-placeholder, input[type=tel]:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #8a8a8a;
  font-style: italic;
}

input[type=text]::-ms-input-placeholder, input[type=email]::-ms-input-placeholder, input[type=url]::-ms-input-placeholder, input[type=password]::-ms-input-placeholder, input[type=search]::-ms-input-placeholder, input[type=number]::-ms-input-placeholder, input[type=tel]::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: #8a8a8a;
  font-style: italic;
}

input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=url]::placeholder,
input[type=password]::placeholder,
input[type=search]::placeholder,
input[type=number]::placeholder,
input[type=tel]::placeholder,
textarea::placeholder {
  color: #8a8a8a;
  font-style: italic;
}

/* Focus States */
input[type=text]:focus,
input[type=email]:focus,
input[type=url]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=number]:focus,
input[type=tel]:focus,
input[type=range]:focus,
input[type=date]:focus,
input[type=month]:focus,
input[type=week]:focus,
input[type=time]:focus,
input[type=datetime]:focus,
input[type=datetime-local]:focus,
input[type=color]:focus,
textarea:focus {
  color: #222;
  border-color: #007cba;
  -webkit-box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1), 0 4px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1), 0 4px 8px rgba(0, 0, 0, 0.1);
  outline: none;
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
}

/* Textarea specific */
textarea {
  min-height: 120px;
  resize: vertical;
}

select {
  border: 2px solid #e1e5e9;
  border-radius: 8px;
  height: 52px;
  max-width: 100%;
  padding: 0 16px;
  font-size: 18px;
  background: #fff;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

select:focus {
  border-color: #007cba;
  -webkit-box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1);
          box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1);
  outline: none;
}

input[type=radio]:focus,
input[type=checkbox]:focus {
  outline: 2px solid #007cba;
  outline-offset: 2px;
}

input[type=radio],
input[type=checkbox] {
  margin-right: 0.75em;
  -webkit-transform: scale(1.2);
          transform: scale(1.2);
}

input[type=radio] + label,
input[type=checkbox] + label {
  font-weight: 400;
  cursor: pointer;
}

/* Modern Buttons */
button,
input[type=button],
input[type=submit] {
  background: linear-gradient(135deg, #007cba 0%, #005a87 100%);
  border: none;
  border-radius: 8px;
  color: #fff;
  cursor: pointer;
  display: inline-block;
  font-size: 18px;
  font-weight: 600;
  line-height: 1;
  padding: 16px 32px;
  text-shadow: none;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-box-shadow: 0 4px 12px rgba(0, 124, 186, 0.3);
          box-shadow: 0 4px 12px rgba(0, 124, 186, 0.3);
  letter-spacing: 0.5px;
  position: relative;
  overflow: hidden;
}

button::before,
input[type=button]::before,
input[type=submit]::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left top, right top, from(transparent), color-stop(rgba(255, 255, 255, 0.2)), to(transparent));
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
  -webkit-transition: left 0.5s;
  transition: left 0.5s;
}

button:hover::before,
input[type=button]:hover::before,
input[type=submit]:hover::before {
  left: 100%;
}

input + button,
input + input[type=button],
input + input[type=submit] {
  padding: 12px 24px;
}

button.secondary,
input[type=reset],
input[type=button].secondary,
input[type=reset].secondary,
input[type=submit].secondary {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  color: #495057;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

:not(.mejs-button) > button:hover,
:not(.mejs-button) > button:focus,
input[type=button]:hover,
input[type=button]:focus,
input[type=submit]:hover,
input[type=submit]:focus {
  background: linear-gradient(135deg, #005a87 0%, #004065 100%);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 6px 16px rgba(0, 124, 186, 0.4);
          box-shadow: 0 6px 16px rgba(0, 124, 186, 0.4);
}

button.secondary:hover,
button.secondary:focus,
input[type=reset]:hover,
input[type=reset]:focus,
input[type=button].secondary:hover,
input[type=button].secondary:focus,
input[type=reset].secondary:hover,
input[type=reset].secondary:focus,
input[type=submit].secondary:hover,
input[type=submit].secondary:focus {
  background: linear-gradient(135deg, #e9ecef 0%, #dee2e6 100%);
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Contact Page Specific Styles */
.contact-section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 20px;
}

.contact-header {
  text-align: center;
  margin-bottom: 60px;
}

.contact-header .contact-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: #333;
  margin-bottom: 16px;
  position: relative;
}

.contact-header .contact-title::after {
  content: "";
  position: absolute;
  bottom: -8px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 80px;
  height: 4px;
  background: linear-gradient(135deg, #007cba 0%, #005a87 100%);
  border-radius: 2px;
}

.contact-header .contact-subtitle {
  font-size: 1.25rem;
  color: #666;
  margin: 0;
  font-weight: 400;
}

.contact-container {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 60px 400px;
  grid-template-columns: 1fr 400px;
  gap: 60px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}

@media (max-width: 768px) {
  .contact-container {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
.contact-form-wrapper .form-container {
  background: #fff;
  padding: 40px;
  border-radius: 16px;
  -webkit-box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
          box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
  border: 1px solid #f0f0f0;
}

.contact-info-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 30px;
}

.contact-method {
  background: #fff;
  padding: 32px;
  border-radius: 16px;
  -webkit-box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
          box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  border: 1px solid #f0f0f0;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.contact-method:hover {
  -webkit-transform: translateY(-4px);
          transform: translateY(-4px);
  -webkit-box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
          box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

.contact-method .contact-icon {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #007cba 0%, #005a87 100%);
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 20px;
}

.contact-method .contact-icon i {
  font-size: 24px;
  color: #fff;
  font-style: normal;
}

.contact-method h3 {
  font-size: 1.3rem;
  font-weight: 600;
  color: #333;
  margin-bottom: 12px;
}

.contact-method p {
  color: #666;
  line-height: 1.6;
  margin-bottom: 16px;
  font-size: 1.1rem;
}

.phone-contact .phone-number {
  margin-bottom: 20px;
}

.phone-contact .phone-number .tel-label {
  display: block;
  font-size: 1.05rem;
  color: #666;
  margin-bottom: 8px;
  font-weight: 500;
}

.phone-contact .phone-number .tel-number {
  display: block;
  font-size: 2rem;
  font-weight: 700;
  color: #007cba;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}

.phone-contact .phone-number .tel-number:hover {
  color: #005a87;
}

.phone-contact .business-hours p {
  margin-bottom: 8px;
  font-size: 1.1rem;
}

.phone-contact .business-hours p:last-child {
  margin-bottom: 0;
}

.office-info .office-details h4 {
  font-size: 1.1rem;
  font-weight: 600;
  color: #333;
  margin-bottom: 16px;
}

.office-info .office-details .address {
  color: #666;
  line-height: 1.6;
  margin-bottom: 12px;
  font-size: 1.1rem;
}

.office-info .office-details .fax {
  color: #666;
  font-size: 1.1rem;
  margin-bottom: 0;
}

/* Form Enhancements */
.form-container .wpcf7-form .wpcf7-form-control-wrap {
  display: block;
  margin-bottom: 20px;
}

.form-container .wpcf7-form .wpcf7-form-control {
  margin-bottom: 0;
}

.form-container .wpcf7-form .wpcf7-submit {
  width: auto;
  margin: 20px auto 0;
  font-size: 1.25rem;
  padding: 18px 40px;
  display: block;
}

/* General form submit button centering */
.form-container form p:last-child {
  text-align: center;
}

.form-container input[type=submit] {
  width: auto;
  margin: 20px auto 0;
  padding: 18px 40px;
  display: block;
}

/* Contact Form 7 送信ボタンの中央寄せを強化 */
.contact-section .wpcf7-form p:last-of-type,
.contact-section .wpcf7-form .wpcf7-submit-wrap,
.form-container .wpcf7-form p:has(.wpcf7-submit),
.form-container .wpcf7-form p.wpcf7-form-submit {
  text-align: center !important;
  margin-bottom: 0;
}

.contact-section .wpcf7-submit,
.form-container .wpcf7-submit {
  width: auto !important;
  margin: 20px auto 0 !important;
  padding: 18px 40px !important;
  display: block !important;
}

/* Simple Contact Page Styles - シンプルなお問い合わせページ */
.contact-section-simple {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
}

.contact-container-simple {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 40px 400px;
  grid-template-columns: 1fr 400px;
  gap: 40px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}

@media (max-width: 768px) {
  .contact-container-simple {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
.contact-form-wrapper-simple .form-container-simple {
  background: transparent;
  padding: 0;
  border-radius: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  border: none;
}

.contact-info-wrapper-simple {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 30px;
}

.contact-method-simple {
  background: transparent;
  padding: 20px 0;
  border-radius: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  border: none;
  border-bottom: 1px solid #eee;
}

.contact-method-simple:last-child {
  border-bottom: none;
}

.contact-method-simple p {
  margin-bottom: 10px;
  font-size: 1.1rem;
}

.contact-method-simple .phone-info,
.contact-method-simple .office-details {
  margin-top: 10px;
}

.contact-method-simple .phone-number {
  margin-bottom: 10px;
}

.contact-method-simple .phone-number .tel-label {
  font-weight: 600;
  margin-right: 8px;
  color: #333;
}

.contact-method-simple .phone-number .tel-number {
  font-size: 1.25rem;
  font-weight: 600;
  color: #007cba;
  text-decoration: none;
}

.contact-method-simple .phone-number .tel-number:hover {
  color: #005a87;
  text-decoration: underline;
}

.contact-method-simple .business-hours p,
.contact-method-simple .office-details p {
  margin-bottom: 5px;
  color: #666;
  font-size: 1rem;
}

/* シンプル版の送信ボタンスタイル */
.contact-section-simple .wpcf7-form p:last-of-type,
.contact-section-simple .wpcf7-form .wpcf7-submit-wrap,
.form-container-simple .wpcf7-form p:has(.wpcf7-submit),
.form-container-simple .wpcf7-form p.wpcf7-form-submit {
  text-align: center !important;
  margin-bottom: 0;
}

.contact-section-simple .wpcf7-submit,
.form-container-simple .wpcf7-submit {
  width: auto !important;
  margin: 20px auto 0 !important;
  padding: 18px 40px !important;
  display: block !important;
}

/*--------------------------------------------------------------
11.0 Featured Image Hover
--------------------------------------------------------------*/
.post-thumbnail {
  margin-bottom: 1em;
}

.post-thumbnail a img {
  -webkit-backface-visibility: hidden;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}

.post-thumbnail a:hover img,
.post-thumbnail a:focus img {
  opacity: 0.7;
}

/*--------------------------------------------------------------
13.4 Posts
--------------------------------------------------------------*/
/* Post Landing Page */
.sticky {
  position: relative;
}

.post:not(.sticky) .icon-thumb-tack {
  display: none;
}

.sticky .icon-thumb-tack {
  display: block;
  height: 18px;
  left: -1.5em;
  position: absolute;
  top: 1.65em;
  width: 20px;
}

.entry-header .entry-title {
  margin-bottom: 0.25em;
}

.entry-title a {
  color: #333;
  text-decoration: none;
  margin-left: -2px;
}

.entry-title:not(:first-child) {
  padding-top: 0;
}

.entry-meta {
  color: #767676;
  font-size: 11px;
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.1818em;
  padding-bottom: 0.25em;
  text-transform: uppercase;
}

.entry-meta a {
  color: #767676;
}

.byline,
.updated:not(.published) {
  display: none;
}

.single .byline,
.group-blog .byline {
  display: inline;
}

.pagination,
.comments-pagination {
  border-top: 1px solid #eee;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 800;
  padding: 2em 0 3em;
  text-align: center;
}

.pagination .icon,
.comments-pagination .icon {
  width: 0.666666666em;
  height: 0.666666666em;
}

.comments-pagination {
  border: 0;
}

.page-numbers {
  display: none;
  padding: 0.5em 0.75em;
}

.page-numbers.current {
  color: #767676;
  display: inline-block;
}

.page-numbers.current .screen-reader-text {
  clip: auto;
  height: auto;
  overflow: auto;
  position: relative !important;
  width: auto;
}

.prev.page-numbers,
.next.page-numbers {
  background-color: #ddd;
  border-radius: 2px;
  display: inline-block;
  font-size: 24px;
  font-size: 1.5rem;
  line-height: 1;
  padding: 0.25em 0.5em 0.4em;
}

.prev.page-numbers,
.next.page-numbers {
  -webkit-transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.3s ease-in-out;
  transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.3s ease-in-out;
}

.prev.page-numbers:focus,
.prev.page-numbers:hover,
.next.page-numbers:focus,
.next.page-numbers:hover {
  background-color: #767676;
  color: #fff;
}

.prev.page-numbers {
  float: left;
}

.next.page-numbers {
  float: right;
}

/* Aligned blockquotes */
.entry-content blockquote.alignleft,
.entry-content blockquote.alignright {
  color: #666;
  font-size: 13px;
  font-size: 0.8125rem;
  width: 48%;
}

/* Blog landing, search, archives */
.blog .site-main > article,
.archive .site-main > article,
.search .site-main > article {
  padding-bottom: 2em;
}

.blog .entry-meta a.post-edit-link,
.archive .entry-meta a.post-edit-link,
.search .entry-meta a.post-edit-link {
  color: #222;
  display: inline-block;
  margin-left: 1em;
  white-space: nowrap;
}

.search .page .entry-meta a.post-edit-link {
  margin-left: 0;
  white-space: nowrap;
}

.taxonomy-description {
  color: #666;
  font-size: 13px;
  font-size: 0.8125rem;
}

/* More tag */
.entry-content .more-link:before {
  content: "";
  display: block;
  margin-top: 1.5em;
}

/* Single Post */
.single-post:not(.has-sidebar) #primary,
.page.page-one-column:not(.twentyseventeen-front-page) #primary,
.archive.page-one-column:not(.has-sidebar) .page-header,
.archive.page-one-column:not(.has-sidebar) #primary {
  margin-left: auto;
  margin-right: auto;
  max-width: 740px;
}

.single-featured-image-header {
  background-color: #fafafa;
  border-bottom: 1px solid #eee;
}

.single-featured-image-header img {
  display: block;
  margin: auto;
}

.page-links {
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 800;
  padding: 2em 0 3em;
}

.page-links .page-number {
  color: #767676;
  display: inline-block;
  padding: 0.5em 1em;
}

.page-links a {
  display: inline-block;
}

.page-links a .page-number {
  color: #222;
}

/* Entry footer */
.entry-footer {
  border-bottom: 1px solid #eee;
  border-top: 1px solid #eee;
  margin-top: 2em;
  padding: 2em 0;
}

.entry-footer .cat-links,
.entry-footer .tags-links {
  display: block;
  font-size: 11px;
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.1818em;
  padding-left: 2.5em;
  position: relative;
  text-transform: uppercase;
}

.entry-footer .cat-links + .tags-links {
  margin-top: 1em;
}

.entry-footer .cat-links a,
.entry-footer .tags-links a {
  color: #333;
}

.entry-footer .cat-links .icon,
.entry-footer .tags-links .icon {
  color: #767676;
  left: 0;
  margin-right: 0.5em;
  position: absolute;
  top: 2px;
}

.entry-footer .edit-link {
  display: inline-block;
}

.entry-footer .edit-link a.post-edit-link {
  background-color: #222;
  border-radius: 2px;
  -webkit-box-shadow: none;
  box-shadow: none;
  color: #fff;
  display: inline-block;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 800;
  margin-top: 2em;
  padding: 0.7em 2em;
  -webkit-transition: background-color 0.2s ease-in-out;
  transition: background-color 0.2s ease-in-out;
  white-space: nowrap;
}

.entry-footer .edit-link a.post-edit-link:hover,
.entry-footer .edit-link a.post-edit-link:focus {
  background-color: #767676;
}

/* Post Formats */
.blog .format-status .entry-title,
.archive .format-status .entry-title,
.blog .format-aside .entry-title,
.archive .format-aside .entry-title {
  display: none;
}

.format-quote blockquote {
  color: #333;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 300;
  overflow: visible;
  position: relative;
}

.format-quote blockquote .icon {
  display: block;
  height: 20px;
  left: -1.25em;
  position: absolute;
  top: 0.4em;
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1);
  width: 20px;
}

/* Post Navigation */
.post-navigation {
  font-weight: 800;
  margin: 3em 0;
}

.post-navigation .nav-links {
  padding: 1em 0;
}

.nav-subtitle {
  background: transparent;
  color: #767676;
  display: block;
  font-size: 11px;
  font-size: 0.6875rem;
  letter-spacing: 0.1818em;
  margin-bottom: 1em;
  text-transform: uppercase;
}

.nav-title {
  color: #333;
  font-size: 15px;
  font-size: 0.9375rem;
}

.post-navigation .nav-next {
  margin-top: 1.5em;
}

.nav-links .nav-previous .nav-title .nav-title-icon-wrapper {
  margin-right: 0.5em;
}

.nav-links .nav-next .nav-title .nav-title-icon-wrapper {
  margin-left: 0.5em;
}

/*--------------------------------------------------------------
13.5 Pages
--------------------------------------------------------------*/
/* 404 page */
.error404 .page-content {
  padding-bottom: 4em;
}

.error404 .page-content .search-form,
.search .page-content .search-form {
  margin-bottom: 3em;
}

/*--------------------------------------------------------------
15.0 Widgets
--------------------------------------------------------------*/
#secondary {
  padding: 1em 0 2em;
}

/* widget forms */
.widget select {
  width: 100%;
}

/* widget lists */
.widget ul {
  list-style: none;
  margin: 0;
}

.widget ul li,
.widget ol li {
  border-bottom: 1px solid #ddd;
  border-top: 1px solid #ddd;
  padding: 0.5em 0;
}

.widget:not(.widget_tag_cloud) ul li + li {
  margin-top: -1px;
}

.widget ul li ul {
  margin: 0 0 -1px;
  padding: 0;
  position: relative;
}

.widget ul li li {
  border: 0;
  padding-left: 24px;
  padding-left: 1.5rem;
}

/* Widget lists of links */
.widget_top-posts ul li ul,
.widget_rss_links ul li ul,
.widget-grofile ul.grofile-links li ul,
.widget_pages ul li ul,
.widget_meta ul li ul {
  bottom: 0;
}

.widget_nav_menu ul li li,
.widget_top-posts ul li,
.widget_top-posts ul li li,
.widget_rss_links ul li,
.widget_rss_links ul li li,
.widget-grofile ul.grofile-links li,
.widget-grofile ul.grofile-links li li {
  padding-bottom: 0.25em;
  padding-top: 0.25em;
}

.widget_rss ul li {
  padding-bottom: 1em;
  padding-top: 1em;
}

/* Widget markup */
.widget .post-date,
.widget .rss-date {
  font-size: 0.81em;
}

/* Text widget */
.widget_text {
  word-wrap: break-word;
}

.widget_text ul {
  list-style: disc;
  margin: 0 0 1.5em 1.5em;
}

.widget_text ol {
  list-style: decimal;
}

.widget_text ul li,
.widget_text ol li {
  border: none;
}

.widget_text ul li:last-child,
.widget_text ol li:last-child {
  padding-bottom: 0;
}

.widget_text ul li ul {
  margin: 0 0 0 1.5em;
}

.widget_text ul li li {
  padding-left: 0;
  padding-right: 0;
}

.widget_text ol li {
  list-style-position: inside;
}

.widget_text ol li + li {
  margin-top: -1px;
}

/* RSS Widget */
.widget_rss .widget-title .rsswidget:first-child {
  float: right;
}

.widget_rss .widget-title .rsswidget:first-child:hover {
  background-color: transparent;
}

.widget_rss .widget-title .rsswidget:first-child img {
  display: block;
}

.widget_rss ul li {
  padding: 2.125em 0;
}

.widget_rss ul li:first-child {
  border-top: none;
  padding-top: 0;
}

.widget_rss li .rsswidget {
  font-size: 22px;
  font-size: 1.375rem;
  font-weight: 300;
  line-height: 1.4;
}

.widget_rss .rss-date,
.widget_rss li cite {
  color: #767676;
  display: block;
  font-size: 10px;
  font-size: 0.625rem;
  font-style: normal;
  font-weight: 800;
  letter-spacing: 0.18em;
  line-height: 1.5;
  text-transform: uppercase;
}

.widget_rss .rss-date {
  margin: 0.5em 0 1.5em;
  padding: 0;
}

.widget_rss .rssSummary {
  margin-bottom: 0.5em;
}

/* Contact Info Widget */
.widget_contact_info .contact-map {
  margin-bottom: 0.5em;
}

/* Gravatar */
.widget-grofile h4 {
  font-size: 16px;
  font-size: 1rem;
  margin-bottom: 0;
}

/* Recent Comments */
.widget_recent_comments table,
.widget_recent_comments th,
.widget_recent_comments td {
  border: 0;
}

/* Recent Posts widget */
.widget_recent_entries .post-date {
  display: block;
}

/* Search */
.search-form {
  position: relative;
}

.search-form .search-submit {
  bottom: 3px;
  padding: 0.5em 1em;
  position: absolute;
  right: 3px;
  top: 3px;
}

.search-form .search-submit .icon {
  height: 24px;
  top: -2px;
  width: 24px;
}

/* Tag cloud widget */
.tagcloud ul li {
  float: left;
  border-top: 0;
  border-bottom: 0;
  padding: 0;
  margin: 4px 4px 0 0;
}

.tagcloud,
.widget_tag_cloud,
.wp_widget_tag_cloud {
  line-height: 1.5;
}

.widget .tagcloud a,
.widget.widget_tag_cloud a,
.wp_widget_tag_cloud a {
  border: 1px solid #ddd;
  -webkit-box-shadow: none;
  box-shadow: none;
  display: block;
  padding: 4px 10px 5px;
  position: relative;
  -webkit-transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.3s ease-in-out;
  transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.3s ease-in-out;
  width: auto;
  word-wrap: break-word;
  z-index: 0;
}

.widget .tagcloud a:hover,
.widget .tagcloud a:focus,
.widget.widget_tag_cloud a:hover,
.widget.widget_tag_cloud a:focus,
.wp_widget_tag_cloud a:hover,
.wp_widget_tag_cloud a:focus {
  border-color: #bbb;
  -webkit-box-shadow: none;
  box-shadow: none;
  text-decoration: none;
}

/* Calendar widget */
.widget_calendar .wp-calendar-table {
  margin-bottom: 0;
}

.widget_calendar .wp-calendar-nav {
  display: table;
  width: 100%;
  margin: 0 0 1.5em;
  padding: 0.4em 0;
}

.widget_calendar .wp-calendar-nav span {
  display: table-cell;
}

.widget_calendar .wp-calendar-nav-prev,
.widget_calendar .wp-calendar-nav-next {
  width: 40%;
}

.widget_calendar th,
.widget_calendar td,
.widget_calendar .wp-calendar-nav span {
  text-align: center;
}

.widget_calendar tfoot td {
  border: 0;
}

/* Gallery widget */
.gallery-columns-5 .gallery-caption,
.gallery-columns-6 .gallery-caption,
.gallery-columns-7 .gallery-caption,
.gallery-columns-8 .gallery-caption,
.gallery-columns-9 .gallery-caption {
  display: none;
}

/*--------------------------------------------------------------
16.0 Media
--------------------------------------------------------------*/
/* SVG Icons base styles */
/*--------------------------------------------------------------
16.1 Galleries
--------------------------------------------------------------*/
.gallery-item {
  display: inline-block;
  text-align: left;
  vertical-align: top;
  margin: 0 0 1.5em;
  padding: 0 1em 0 0;
  width: 50%;
}

.gallery-columns-1 .gallery-item {
  width: 100%;
}

.gallery-columns-2 .gallery-item {
  max-width: 50%;
}

.gallery-item a,
.gallery-item a:hover,
.gallery-item a:focus,
.widget-area .gallery-item a,
.widget-area .gallery-item a:hover,
.widget-area .gallery-item a:focus {
  -webkit-box-shadow: none;
  box-shadow: none;
  background: none;
  display: inline-block;
  max-width: 100%;
}

.gallery-item a img {
  display: block;
  -webkit-transition: -webkit-filter 0.2s ease-in;
  transition: -webkit-filter 0.2s ease-in;
  transition: filter 0.2s ease-in;
  transition: filter 0.2s ease-in, -webkit-filter 0.2s ease-in;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.gallery-item a:hover img,
.gallery-item a:focus img {
  -webkit-filter: opacity(60%);
  filter: opacity(60%);
}

.gallery-caption {
  display: block;
  text-align: left;
  padding: 0 10px 0 0;
  margin-bottom: 0;
}

/*--------------------------------------------------------------
18.0 SVGs Fallbacks
--------------------------------------------------------------*/
.svg-fallback {
  display: none;
}

.no-svg .svg-fallback {
  display: inline-block;
}

.no-svg .dropdown-toggle {
  padding: 0.5em 0 0;
  right: 0;
  text-align: center;
  width: 2em;
}

.no-svg .dropdown-toggle .svg-fallback.icon-angle-down {
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1;
  -webkit-transform: rotate(180deg); /* Chrome, Safari, Opera */ /* IE 9 */
  transform: rotate(180deg);
}

.no-svg .dropdown-toggle.toggled-on .svg-fallback.icon-angle-down {
  -webkit-transform: rotate(0); /* Chrome, Safari, Opera */ /* IE 9 */
  transform: rotate(0);
}

.no-svg .dropdown-toggle .svg-fallback.icon-angle-down:before {
  content: "^";
}

/* Social Menu fallbacks */
.no-svg .social-navigation a {
  background: transparent;
  color: #222;
  height: auto;
  width: auto;
}

/* Show screen reader text in some cases */
.no-svg .next.page-numbers .screen-reader-text,
.no-svg .prev.page-numbers .screen-reader-text,
.no-svg .social-navigation li a .screen-reader-text,
.no-svg .search-submit .screen-reader-text {
  clip: auto;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 400;
  height: auto;
  position: relative !important; /* overrides previous !important styles */
  width: auto;
}

/*--------------------------------------------------------------
19.0 Media Queries
--------------------------------------------------------------*/
@media screen and (min-width: 48em) {
  /* Layout */
  .wrap {
    max-width: 1000px;
    padding-left: 3em;
    padding-right: 3em;
  }
  .has-sidebar:not(.error404) #primary {
    float: left;
    width: 58%;
  }
  .error404 #primary {
    float: none;
  }
  /* Site Branding */
  .site-branding {
    margin-bottom: 0;
  }
  .has-header-image.twentyseventeen-front-page .site-branding,
  .has-header-video.twentyseventeen-front-page .site-branding,
  .has-header-image.home.blog .site-branding,
  .has-header-video.home.blog .site-branding {
    bottom: 0;
    display: block;
    left: 0;
    height: auto;
    padding-top: 0;
    position: absolute;
    width: 100%;
  }
  .has-header-image.twentyseventeen-front-page .custom-header,
  .has-header-video.twentyseventeen-front-page .custom-header,
  .has-header-image.home.blog .custom-header,
  .has-header-video.home.blog .custom-header {
    display: block;
    height: auto;
  }
  .custom-header-media {
    height: 165px;
    position: relative;
  }
  .twentyseventeen-front-page.has-header-image .custom-header-media,
  .twentyseventeen-front-page.has-header-video .custom-header-media,
  .home.blog.has-header-image .custom-header-media,
  .home.blog.has-header-video .custom-header-media {
    height: 0;
    position: relative;
  }
  .has-header-image:not(.twentyseventeen-front-page):not(.home) .custom-header-media,
  .has-header-video:not(.twentyseventeen-front-page):not(.home) .custom-header-media {
    bottom: 0;
    height: auto;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
  }
  .custom-logo-link {
    padding-right: 2em;
  }
  .custom-logo-link img,
  body.home.title-tagline-hidden.has-header-image .custom-logo-link img,
  body.home.title-tagline-hidden.has-header-video .custom-logo-link img {
    max-width: 350px;
  }
  .title-tagline-hidden.home.has-header-image .custom-logo-link img,
  .title-tagline-hidden.home.has-header-video .custom-logo-link img {
    max-height: 200px;
  }
  /* Navigation */
  .navigation-top {
    bottom: 0;
    font-size: 14px;
    font-size: 0.875rem;
    left: 0;
    position: absolute;
    right: 0;
    width: 100%;
    z-index: 3;
  }
  .navigation-top .wrap {
    max-width: 1000px;
    /* The font size is 14px here and we need 50px padding in ems */
    padding: 0.75em 3.4166666667em;
  }
  .navigation-top nav {
    margin-left: -1.25em;
  }
  .site-navigation-fixed.navigation-top {
    bottom: auto;
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 7;
  }
  .admin-bar .site-navigation-fixed.navigation-top {
    top: 32px;
  }
  /* Main Navigation */
  .js .menu-toggle,
  .js .dropdown-toggle {
    display: none;
  }
  .main-navigation {
    width: auto;
  }
  .js .main-navigation ul,
  .js .main-navigation ul ul,
  .js .main-navigation > div > ul {
    display: block;
  }
  .main-navigation ul {
    background: transparent;
    padding: 0;
  }
  .main-navigation > div > ul {
    border: 0;
    margin-bottom: 0;
    padding: 0;
  }
  .main-navigation li {
    border: 0;
    display: inline-block;
  }
  .main-navigation li li {
    display: block;
  }
  .main-navigation a {
    padding: 1em 1.25em;
  }
  .main-navigation ul ul {
    background: #fff;
    border: 1px solid #bbb;
    left: -999em;
    padding: 0;
    position: absolute;
    top: 100%;
    z-index: 99999;
  }
  .main-navigation ul li.menu-item-has-children:before,
  .main-navigation ul li.menu-item-has-children:after,
  .main-navigation ul li.page_item_has_children:before,
  .main-navigation ul li.page_item_has_children:after {
    border-style: solid;
    border-width: 0 6px 6px;
    content: "";
    display: none;
    height: 0;
    position: absolute;
    right: 1em;
    bottom: -1px;
    width: 0;
    z-index: 100000;
  }
  .main-navigation ul li.menu-item-has-children.focus:before,
  .main-navigation ul li.menu-item-has-children:hover:before,
  .main-navigation ul li.menu-item-has-children.focus:after,
  .main-navigation ul li.menu-item-has-children:hover:after,
  .main-navigation ul li.page_item_has_children.focus:before,
  .main-navigation ul li.page_item_has_children:hover:before,
  .main-navigation ul li.page_item_has_children.focus:after,
  .main-navigation ul li.page_item_has_children:hover:after {
    display: block;
  }
  .main-navigation ul li.menu-item-has-children:before,
  .main-navigation ul li.page_item_has_children:before {
    border-color: transparent transparent #bbb;
    bottom: 0;
  }
  .main-navigation ul li.menu-item-has-children:after,
  .main-navigation ul li.page_item_has_children:after {
    border-color: transparent transparent #fff;
  }
  .main-navigation ul ul li:hover > ul,
  .main-navigation ul ul li.focus > ul {
    left: 100%;
    right: auto;
  }
  .main-navigation ul ul a {
    padding: 0.75em 1.25em;
    width: 16em;
  }
  .main-navigation li li {
    -webkit-transition: background-color 0.2s ease-in-out;
    transition: background-color 0.2s ease-in-out;
  }
  .main-navigation li li:hover,
  .main-navigation li li.focus {
    background: #767676;
  }
  .main-navigation li li a {
    -webkit-transition: color 0.3s ease-in-out;
    transition: color 0.3s ease-in-out;
  }
  .main-navigation li li.focus > a,
  .main-navigation li li:focus > a,
  .main-navigation li li:hover > a,
  .main-navigation li li a:hover,
  .main-navigation li li a:focus,
  .main-navigation li li.current_page_item a:hover,
  .main-navigation li li.current-menu-item a:hover,
  .main-navigation li li.current_page_item a:focus,
  .main-navigation li li.current-menu-item a:focus {
    color: #fff;
  }
  .main-navigation ul li:hover > ul,
  .main-navigation ul li.focus > ul {
    left: 0.5em;
    right: auto;
  }
  .main-navigation .menu-item-has-children > a > .icon,
  .main-navigation .page_item_has_children > a > .icon {
    display: inline;
    left: 5px;
    position: relative;
    top: -1px;
  }
  .main-navigation ul ul .menu-item-has-children > a > .icon,
  .main-navigation ul ul .page_item_has_children > a > .icon {
    margin-top: -9px;
    left: auto;
    position: absolute;
    right: 1em;
    top: 50%;
    -webkit-transform: rotate(-90deg); /* Chrome, Safari, Opera */ /* IE 9 */
    transform: rotate(-90deg);
  }
  .main-navigation ul ul ul {
    left: -999em;
    margin-top: -1px;
    top: 0;
  }
  .main-navigation ul ul li.menu-item-has-children.focus:before,
  .main-navigation ul ul li.menu-item-has-children:hover:before,
  .main-navigation ul ul li.menu-item-has-children.focus:after,
  .main-navigation ul ul li.menu-item-has-children:hover:after,
  .main-navigation ul ul li.page_item_has_children.focus:before,
  .main-navigation ul ul li.page_item_has_children:hover:before,
  .main-navigation ul ul li.page_item_has_children.focus:after,
  .main-navigation ul ul li.page_item_has_children:hover:after {
    display: none;
  }
  .site-header .site-navigation-fixed .menu-scroll-down {
    display: none;
  }
  /* Scroll down arrow */
  .site-header .menu-scroll-down {
    display: block;
    padding: 1em;
    position: absolute;
    right: 0;
  }
  .site-header .menu-scroll-down .icon {
    -webkit-transform: rotate(90deg); /* Chrome, Safari, Opera */ /* IE 9 */
    transform: rotate(90deg);
  }
  .site-header .menu-scroll-down {
    color: #fff;
    top: 2em;
  }
  .site-header .navigation-top .menu-scroll-down {
    color: #767676;
    top: 0.7em;
  }
  .menu-scroll-down:focus {
    outline: thin dotted;
  }
  .menu-scroll-down .icon {
    height: 18px;
    width: 18px;
  }
  /* Front Page */
  .twentyseventeen-front-page.has-header-image .site-branding,
  .twentyseventeen-front-page.has-header-video .site-branding,
  .home.blog.has-header-image .site-branding,
  .home.blog.has-header-video .site-branding {
    margin-bottom: 70px;
  }
  .twentyseventeen-front-page.has-header-image .custom-header-media,
  .twentyseventeen-front-page.has-header-video .custom-header-media,
  .home.blog.has-header-image .custom-header-media,
  .home.blog.has-header-video .custom-header-media {
    height: 1200px;
    height: 100vh;
    max-height: 100%;
    overflow: hidden;
  }
  .twentyseventeen-front-page.has-header-image .custom-header-media:before,
  .twentyseventeen-front-page.has-header-video .custom-header-media:before,
  .home.blog.has-header-image .custom-header-media:before,
  .home.blog.has-header-video .custom-header-media:before {
    height: 33%;
  }
  .admin-bar.twentyseventeen-front-page.has-header-image .custom-header-media,
  .admin-bar.twentyseventeen-front-page.has-header-video .custom-header-media,
  .admin-bar.home.blog.has-header-image .custom-header-media,
  .admin-bar.home.blog.has-header-video .custom-header-media {
    height: calc(100vh - 32px);
  }
  .panel-content .wrap {
    padding-bottom: 4.5em;
    padding-top: 6em;
  }
  .panel-image {
    height: 100vh;
    max-height: 1200px;
  }
  /* With panel images 100% of the screen height, we're going to fix the background image where supported to create a parallax-like effect. */
  .background-fixed .panel-image {
    background-attachment: fixed;
  }
  .page-two-column .panel-content .entry-header {
    float: left;
    width: 36%;
  }
  .page-two-column .panel-content .entry-content {
    float: right;
    width: 58%;
  }
  /* Front Page - Recent Posts */
  .page-two-column .panel-content .recent-posts {
    clear: right;
    float: right;
    width: 58%;
  }
  .panel-content .recent-posts article {
    margin-bottom: 4em;
  }
  .panel-content .recent-posts .entry-header,
  .page-two-column #primary .panel-content .recent-posts .entry-header,
  .panel-content .recent-posts .entry-content,
  .page-two-column #primary .panel-content .recent-posts .entry-content {
    float: none;
    width: 100%;
  }
  .panel-content .recent-posts .entry-header {
    margin-bottom: 1.5em;
  }
  .page .panel-content .recent-posts .entry-title {
    font-size: 26px;
    font-size: 1.625rem;
  }
  /* Posts */
  .site-content {
    padding: 5.5em 0 0;
  }
  .single-post .entry-title,
  .page .entry-title {
    font-size: 26px;
    font-size: 1.625rem;
  }
  .comments-pagination,
  .post-navigation {
    clear: both;
  }
  .post-navigation .nav-previous {
    float: left;
    width: 50%;
  }
  .post-navigation .nav-next {
    float: right;
    text-align: right;
    width: 50%;
  }
  .nav-next,
  .post-navigation .nav-next {
    margin-top: 0;
  }
  /* Blog, archive, search */
  .sticky .icon-thumb-tack {
    height: 23px;
    left: -2.5em;
    top: 1.5em;
    width: 32px;
  }
  .blog .site-main > article,
  .archive .site-main > article,
  .search .site-main > article {
    padding-bottom: 4em;
  }
  .navigation.pagination {
    clear: both;
    float: right;
    width: 58%;
    position: relative;
  }
  .has-sidebar .navigation.pagination,
  .archive.page-one-column:not(.has-sidebar) .navigation.pagination {
    float: none;
    width: 100%;
  }
  .entry-footer {
    display: table;
    width: 100%;
  }
  .entry-footer .cat-tags-links {
    display: table-cell;
    vertical-align: middle;
    width: 100%;
  }
  .entry-footer .edit-link {
    display: table-cell;
    text-align: right;
    vertical-align: middle;
  }
  .entry-footer .edit-link a.post-edit-link {
    margin-top: 0;
    margin-left: 1em;
  }
  /* Entry content */
  /* without sidebar */
  :not(.has-sidebar) .entry-content blockquote.alignleft {
    margin-left: -17.5%;
    width: 48%;
  }
  :not(.has-sidebar) .entry-content blockquote.alignright {
    margin-right: -17.5%;
    width: 48%;
  }
  /* with sidebar */
  .has-sidebar .entry-content blockquote.alignleft {
    margin-left: 0;
    width: 34%;
  }
  .has-sidebar .entry-content blockquote.alignright {
    margin-right: 0;
    width: 34%;
  }
  .has-sidebar #primary .entry-content blockquote.alignright.below-entry-meta {
    margin-right: -72.5%;
    width: 62%;
  }
  /* blog and archive */
  .blog:not(.has-sidebar) .entry-content blockquote.alignleft,
  .twentyseventeen-front-page.page-two-column .entry-content blockquote.alignleft,
  .archive:not(.has-sidebar) .entry-content blockquote.alignleft,
  .page-two-column .entry-content blockquote.alignleft {
    margin-left: -72.5%;
    width: 62%;
  }
  .blog:not(.has-sidebar) .entry-content blockquote.alignright,
  .twentyseventeen-front-page.page-two-column .entry-content blockquote.alignright,
  .archive:not(.has-sidebar) .entry-content blockquote.alignright,
  .page-two-column .entry-content blockquote.alignright {
    margin-right: 0;
    width: 36%;
  }
  /* Post formats */
  .format-quote blockquote .icon {
    left: -1.5em;
  }
  /* Pages */
  .page.page-one-column .entry-header,
  .twentyseventeen-front-page.page-one-column .entry-header,
  .archive.page-one-column:not(.has-sidebar) .page-header {
    margin-bottom: 4em;
  }
  .page:not(.home) #content {
    padding-bottom: 3.25em;
  }
  /* 404 page */
  .error404 .page-content {
    padding-bottom: 9em;
  }
  /* Gallery Columns */
  .gallery-columns-5 .gallery-item {
    max-width: 20%;
  }
  .gallery-columns-6 .gallery-item {
    max-width: 16.66%;
  }
  .gallery-columns-7 .gallery-item {
    max-width: 14.28%;
  }
  .gallery-columns-8 .gallery-item {
    max-width: 12.5%;
  }
  .gallery-columns-9 .gallery-item {
    max-width: 11.11%;
  }
}
@media screen and (min-width: 67em) {
  /* Sticky posts */
  .sticky .icon-thumb-tack {
    font-size: 32px;
    font-size: 2rem;
    height: 22px;
    left: -1.25em;
    top: 0.75em;
    width: 32px;
  }
  /* Pagination */
  .page-numbers {
    display: inline-block;
  }
  .page-numbers.current {
    font-size: 15px;
    font-size: 0.9375rem;
  }
  .page-numbers.current .screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    overflow: hidden;
    position: absolute !important;
    width: 1px;
  }
}
/* ハンバーガーメニューのスタイル */
.navbar-toggler {
  background: #ffffff !important;
  background-color: #ffffff !important;
  background-image: none !important;
  border: 1px solid #dee2e6 !important;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
  padding: 4px 8px !important;
}

.navbar-toggler:focus {
  background: #ffffff !important;
  background-color: #ffffff !important;
  background-image: none !important;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
  outline: none !important;
}

.navbar-toggler:hover {
  background: #f8f9fa !important;
  background-color: #f8f9fa !important;
  background-image: none !important;
}

.wrap {
  margin-top: 40px;
  text-align: left !important;
}
.wrap h1 {
  text-align: left;
  border-bottom: 1px #222 solid;
}

.entry-meta {
  text-align: right;
}

h2.widget-title {
  margin-bottom: 10px;
  margin-left: 0;
  margin-right: 0;
  font-family: "a-otf-ud-shin-go-pr6n", sans-serif;
}

dl {
  clear: both;
}
dl dt, dl dd {
  float: left;
}

aside#secondary {
  padding: 0;
}
aside section {
  margin: 0;
  padding: 0;
}
aside section h2.widget-title {
  font-family: YakuHanJP, "source-han-sans-cjk-ja", sans-serif;
  font-weight: 400;
  font-size: 1rem !important;
  background-color: inherit;
  text-align: left;
  color: #fff;
  background-color: #fd7279;
  padding: 5px 10px !important;
  width: auto;
  letter-spacing: 0 !important;
  margin-bottom: 20px !important;
  display: block !important;
}
aside section p {
  font-size: 1rem !important;
  line-height: 1.2 !important;
  padding-left: 18px;
}
aside section ul {
  font-size: 0.9rem;
  margin-left: 0;
  padding-left: 15px;
  padding-right: 15px;
}
aside section.widget {
  margin-bottom: 30px;
}

.nav-links {
  width: 100%;
}

.page-numbers {
  font-size: 1.3rem;
}