/*
Theme Name: twentyseventeen Child
Version: 1.6
Template: twentyseventeen
*/
/* ローディング画面 */
html.loading {
    overflow: hidden;
}

.loading-content {
    text-align: center;
    transform: translateY(-20px);
    animation: fadeInUp 0.8s ease-out forwards;
}

.loading-logo h1 {
    font-size: 2.5rem;
    color: #333333;
    margin-bottom: 30px;
    font-weight: 300;
    letter-spacing: 2px;
    font-family: 'Lato', sans-serif;
}

.loading-spinner {
    margin-top: 20px;
}

.spinner {
    width: 40px;
    height: 40px;
    border: 3px solid #f0f0f0;
    border-top: 3px solid #333333;
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ローディング系統合スタイル */
.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#fff;z-index:9999;display:flex;justify-content:center;align-items:center;opacity:1;visibility:visible;transition:opacity .5s ease,visibility .5s ease}
.loading-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}
.welcome-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:10001}
.welcome-text h1{font-size:2.5rem;font-weight:300;color:#333;margin:0;letter-spacing:2px;font-family:'Lato',sans-serif;text-transform:uppercase;white-space:nowrap;overflow:hidden;border-right:2px solid #333;width:0;animation:typing 2s steps(29,end) .5s forwards,blink-caret .75s step-end infinite,hideCaret 0s 2.5s forwards}
@media (max-width:768px){.welcome-text h1{font-size:1.8rem;letter-spacing:1px}}
@media (max-width:480px){.welcome-text h1{font-size:1.4rem;letter-spacing:.5px}}
@keyframes typing{from{width:0}to{width:100%}}
@keyframes blink-caret{from,to{border-color:transparent}50%{border-color:#333}}
@keyframes hideCaret{to{border-color:transparent}}
.loading-curtain{position:absolute;top:0;right:-100%;width:100%;height:100%;background:linear-gradient(135deg,#000 0%,#333 100%);z-index:10002;transition:right .3s cubic-bezier(.25,.46,.45,.94)}
.loading-curtain.slide-in{right:0}
.loading-curtain.slide-out{right:-100%}
.loading-curtain-white{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(135deg,#fff 0%,#f0f0f0 100%);z-index:10003;transition:left .8s cubic-bezier(.25,.46,.45,.94)}
.loading-curtain-white.slide-in{left:0}
.loading-curtain-white.slide-out{left:100%}
.welcome-text.fade-out{opacity:0;transition:opacity .3s ease-out}

.loading-content {
    text-align: center;
}

.loading-logo h1 {
    font-size: 2.5rem;
    color: #333;
    margin-bottom: 30px;
    font-weight: 300;
    letter-spacing: 2px;
    animation: fadeInUp 1s ease;
}

.loading-spinner {
    margin-top: 20px;
}

.spinner {
    width: 40px;
    height: 40px;
    border: 3px solid #f3f3f3;
    border-top: 3px solid #333;
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ローディング中はスクロールを無効にする */
body.loading {
    overflow: hidden;
}

/* アニメーション定義 */
@keyframes slideIn {
    from { opacity: 0; transform: translateX(-20px) scale(0.95); }
    to { opacity: 1; transform: translateX(0) scale(1); }
}

@keyframes fadeUp {
    from { opacity: 0; transform: translateY(15px) scale(0.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes fadeOut {
    from { opacity: 1; transform: scale(1); }
    to { opacity: 0; transform: scale(1.02); }
}

@keyframes logoDisplay {
    0% {
        opacity: 0;
        transform: scale(0.8);
    }
    50% {
        opacity: 1;
        transform: scale(1);
    }
    100% {
        opacity: 0;
        transform: scale(1.1);
    }
}

@keyframes rollUp {
    0% {
        height: 0;
    }
    100% {
        height: 100%;
    }
}

@keyframes fadeOut {
    0% {
        opacity: 1;
        visibility: visible;
    }
    100% {
        opacity: 0;
        visibility: hidden;
    }
}

/* メインコンテンツの初期状態 */
#page {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.6s ease;
}

#page.show {
    opacity: 1;
    transform: translateY(0);
}

/* ファーストビューがない場合のフォールバック */
body:not(.first-view-active) #page {
    opacity: 1;
    transform: translateY(0);
}

/* トップに戻るボタン */
#back-to-top {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 50px;
    height: 50px;
    background: #333;
    color: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    display: none;
    z-index: 10000;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
    font-size: 18px;
    align-items: center;
    justify-content: center;
}

#back-to-top:hover {
    background: #555;
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
}

#back-to-top.show {
    display: flex;
    animation: fadeInScale 0.3s ease;
}

@keyframes fadeInScale {
    from {
        opacity: 0;
        transform: scale(0.8);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* ポートフォリオアイテムの順次表示アニメーション */
.portfolio-item {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.6s ease-out, opacity 0.3s ease, transform 0.3s ease;
}

.portfolio-item.animate-in {
    opacity: 1;
    transform: translateY(0);
}

/* ポートフォリオアイテムのホバー効果 */
.portfolio-item:hover,
.portfolio-item.animate-in:hover,
body:not(.first-view-active) .portfolio-item:hover,
.portfolio-fallback .portfolio-item:hover {
    opacity: 0.7 !important;
    transform: translateY(-2px) !important;
}

.portfolio-item .job_img {
    display: block;
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

/* カーテンアニメーション用疑似要素 */
.portfolio-item .job_img::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    transform: translateX(100%);
    transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    z-index: 1;
}

/* ホバー時にカーテンが右から左へスライド */
.portfolio-item:hover .job_img::before {
    transform: translateX(-100%);
}

/* ホバー時にカーテンが右から左へスライド */
.portfolio-item:hover .job_img::before {
    transform: translateX(-100%);
}

/* スクロール時のカーテンアニメーション */
.portfolio-item .job_img.curtain-reveal::before {
    transform: translateX(-100%);
}

/* カーテンアニメーション完了後の画像表示 */
.portfolio-item .job_img img {
    opacity: 0;
    transform: scale(1.1);
    transition: opacity 0.6s ease 0.3s, transform 0.8s ease 0.3s;
}

.portfolio-item .job_img.curtain-reveal img {
    opacity: 1;
    transform: scale(1);
}

/* AJAX読み込み時の画像表示（カーテンアニメーションなしの場合） */
.portfolio-item.animate-in .job_img img {
    opacity: 1;
    transform: scale(1);
}

.portfolio-item:hover .job_img {
    transform: scale(1.05);
}

/* ファーストビューがない場合のフォールバック */
body:not(.first-view-active) .portfolio-item {
    opacity: 1;
    transform: translateY(0);
}

/* 5秒後の強制表示（フォールバック） */
.portfolio-fallback .portfolio-item {
    opacity: 1;
    transform: translateY(0);
}

/* 「もっと見る」ボタンスタイル */
.load-more-container {
    text-align: center;
    margin: 40px 0;
}

.load-more-btn {
    background: #333;
    color: white;
    border: none;
    padding: 12px 30px;
    font-size: 16px;
    cursor: pointer;
    border-radius: 5px;
    transition: all 0.3s ease;
}

.load-more-btn:hover {
    background: #555;
    transform: translateY(-2px);
}

.load-more-btn:disabled {
    background: #ccc;
    cursor: not-allowed;
    transform: none;
}

/* カテゴリメニューのホバー効果 */
.menu-bt ul li a {
    transition: all 0.3s ease;
    padding: 8px 15px;
    display: inline-block;
}

.menu-bt ul li a:hover {
    background-color: rgb(0 0 0 / 80%);
    color: #fff !important;
}

html.wprmenu-body-fixed {
  overflow: scroll !important;
}
h1,h2,h3,h4,h5,p,div,li{
  margin: 0;
  padding: 0;
  list-style: none;
}
#primary{
    float: none !important;
    width: 100% !important;
}
.site-title a{
  color: #000 !important;
}
.magin_auto{
  margin: 0 auto;
}
.site_ca {
  position: absolute;
  top: 50px;
  left: 45px;
  font-size: 10px;
}
.site-content{
    padding: 0em 0 0;
}
/*ナビゲーション*/
.site-title {
    position: absolute;
    top: 30px;
    left: 45px;
}
.main_mv{
  width: 100%;
  overflow: hidden;
  margin: 0 auto;
}
#header-menu ul{
    display: flex;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    -webkit-align-items: flex-end;
    align-items: flex-end;
}
#header-menu li{
  padding: 10px;
}

/* ヘッダーメニューリンクのスタイル */
#header-menu a {
  color: #333;
  text-decoration: none;
  padding: 8px 16px;
  border-radius: 4px;
  transition: all 0.3s ease;
  display: block;
  position: relative;
  overflow: hidden;
}

#header-menu a:hover {
  background-color: #333;
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

#header-menu a:active {
  transform: translateY(0);
}
.menu-bt ul{
  display:flex;
  padding: 0px 10px;
}
.menu-bt li{
  padding: 0px 10px 0px 0px;
}
/*メインカラム*/
.wrap{
  max-width: 90%;
  width: 90%;
}
.site-title {
    font-size: 1em;
}
/*トップメインテキスト*/
.main_text{
  margin: 4% 0px 6%;
  font-size: 1.7em;
  text-transform: uppercase;
}
.inn{
  font-family: 'Lato', sans-serif !important;
}
.job_txt h3,p{
  font-size:0.9em;
}
.job_txt p a{
  color: #8e8c8c;
}
.wark{
  margin: 20px 0px;
}
.wark ul{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 20px;
}
.widget_tag_cloud p{
  display:flex;
}
.wp-block-heading{
  font-size:1em;
}
.menu_title {
    display: none;
}

@keyframes bg {
  0% {
    opacity: 0;
    transform: scaleX(0) translateX(-5%);
  }
  30% {
    transform: scaleX(1) translateX(0);
  }
  100% {
    transform: scaleX(1) translateX(0);
  }
  30%, 100% {
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/*メインテキストアニメーション*/
.bg .bg-wrap {
  position: relative;
  display: inline-block;
  margin-top: 5px;
}
.bg.is-animated .bg-wrap::before {
  animation: bg 4s cubic-bezier(0.215, 0.61, 0.355, 1) forwards;
  background: rgb(0 0 0 / 80%);
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-origin: left center;
}
.bg.is-animated2 .bg-wrap::before {
  opacity: 0;
  animation: bg 4s cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s forwards;
  background: rgb(0 0 0 / 80%);
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-origin: left center;
}
.bg .bg-wrap .inn {
  opacity: 0;
  animation: fadeIn 1s ease 1s forwards;
  color: #fff;
  display: inline-block;
  font-size: 36px;
  padding: 5px 15px;
  font-family: 'Noto Serif JP', serif;
  position: relative;
  z-index: 1;
}
.bg.is-animated2 .bg-wrap .inn {
  opacity: 0;
  animation: fadeIn 1s ease 1.3s forwards;
}

/*home*/
.category-all .wark img{
    width: 100%;
    max-width: 100%;
}
/*work*/
.wark img{
  overflow:hidden;
  width: 100%;
  transition: transform 0.3s ease;
}

.portfolio-item .job_img {
    display: block;
    overflow: hidden;
    border-radius: 4px;
}

/*sidebar*/
.single #primary {
  display: flex;
}
.single #secondary {
  width: 90%;
}
.sidebar{
  display: none;
}

/*single.php*/
.single .site-main {
    width: 100%;
}
.single .content-area {
    max-width: 1200px;
    margin: 0 auto;
}
.block1{
    line-height: 2.4em;
    padding: 10px 0px;
}
.img-style001{
    padding: 50px 10px;
}
h2{
    margin: 30px 0px;
}
.company_name{
  font-weight: bold;
}
img.ls-is-cached.lazyloaded{
  width: 100%;
}
.project-images-wrapper {
    display: flex;
    justify-content: space-between;
    gap: 20px;
}
@media screen and (max-width: 959px) {
  /* 959px以下に適用されるCSS（タブレット用） */
.wark ul{
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: none;
  gap: 20px;
}
.main_text{
  font-size: 1.4em;
}
#wprmenu_bar .menu_title {
    display: none;
}
.bg .bg-wrap .inn {
    font-size: 26px;
}
}

@media screen and (max-width: 768px) {
.menu_title {
    display: block;
}
.bg .bg-wrap .inn {
    font-size: 20px;
}
#header-menu {
    display: none;
}
#wprmenu_bar {
    background-color: #000000;
}
.wrap.magin_auto.header-menu {
  height: calc( 100px - 30px );
}

/* ファーストビューのモバイル対応 */
.first-view-logo {
    font-size: 2rem;
    letter-spacing: 2px;
}

.first-view-subtitle {
    font-size: 0.8rem;
    letter-spacing: 0.8px;
    margin: 10px 0 0 0;
}
}


@media screen and (max-width: 640px) {
.wark ul{
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: none;
  gap: 20px;
}
.main_text{
  font-size: 1.2em;
}
.menu_title {
  display: block;
}
.bg .bg-wrap .inn {
  font-size: 14px;
}
.single #primary {
  display: block;
}
.single .site-main {
  width: 100%;
}
.wrap.magin_auto.header-menu {
  height: calc( 170px - 30px );
}
.site_ca {
  position: unset;
}
h1.site-title {
  position: unset;
  font-size: 1.6em;
}
.site-branding-text{
  width: 100%;
  text-align: center;
  padding: 60px 0px;
}

/* ファーストビューのスマホ対応 */
.first-view-logo {
    font-size: 1.5rem;
    letter-spacing: 1px;
}

.first-view-subtitle {
    font-size: 0.7rem;
    letter-spacing: 0.5px;
    margin: 8px 0 0 0;
}

/* ローディングカーテンエフェクト */
.loading-curtain {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.9) 0%, rgba(51, 51, 51, 0.9) 100%);
    z-index: 9999;
    transform: translateY(100%);
    animation: curtainUp 1s ease-in-out forwards;
}

.loading-curtain.curtain-close {
    animation: curtainDown 1s ease-in-out forwards;
}

@keyframes curtainUp {
    from {
        transform: translateY(100%);
    }
    to {
        transform: translateY(0%);
    }
}

@keyframes curtainDown {
    from {
        transform: translateY(0%);
    }
    to {
        transform: translateY(-100%);
    }
}

/* ポートフォリオアイテムのホバー効果 - 最優先 */
.wark .portfolio-item:hover,
.wark li.portfolio-item:hover,
.wark li.flex-item1:hover {
    opacity: 0.7 !important;
    transform: translateY(-2px) !important;
    transition: all 0.3s ease !important;
}

.wark .portfolio-item:hover .job_img img,
.wark li.portfolio-item:hover .job_img img {
    transform: scale(1.05) !important;
    transition: transform 0.3s ease !important;
}

/* プロジェクト画像のスタイル */
.project-images-wrapper {
    display: flex;
    gap: 10px;
    margin: 20px 0;
    width: 100%;
}

.project-image-container {
    flex: 1;
    width: 100%;
    display: block;
    overflow: hidden;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.project-image {
    width: 100% !important;
    height: 1500px !important;
    object-fit: cover !important;
    object-position: top !important;
    display: block;
    transition: transform 0.3s ease;
}

.project-image:hover {
    transform: scale(1.02);
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
    .project-images-wrapper {
        flex-direction: column;
        gap: 15px;
        margin: 15px 0;
    }
    
    .project-image-container {
        border-radius: 4px;
    }
    
    .project-image {
        height: 1000px !important;
    }
}

@media (max-width: 480px) {
    .project-images-wrapper {
        gap: 10px;
    }
    
    .project-image {
        height: 800px !important;
    }
}

