@charset "UTF-8";
.container { width: 1100px; margin: 0 auto; }
@media (max-width: 1200px) { .container { width: 100%; padding: 0px 20px; } }

.narrow { width: 770px; margin: 0 auto; }
@media (max-width: 770px) { .narrow { width: 100%; padding: 0px 20px; } }

.pc-only { display: block; }
@media screen and (max-width: 768px) { .pc-only { display: none; } }

.sp-only { display: none; }
@media screen and (max-width: 768px) { .sp-only { display: block; } }

article#page { font-family: "Noto Serif JP", serif; }
article#page .ttl { background: #010002; padding: 2.5rem 0; color: #fff; position: relative; margin-top: 5px; }
article#page .ttl h2 { font-family: "Gilda Display", serif; font-size: 2.4rem; line-height: 1.1; letter-spacing: 0.3rem; }
article#page .ttl h2 span { font-family: "Noto Serif JP", serif; display: block; font-size: 1.2rem; letter-spacing: 0rem; }
article#page .ttl::after { content: ''; border: none; height: calc(100% + 10px); width: 100%; display: inline-block; position: absolute; background: linear-gradient(90deg, #797979 0%, #fff 54%, #c2c2c2 83%, #797979 100%); top: -5px; left: 0; bottom: auto; z-index: -1; }
@media screen and (max-width: 559px) { article#page .ttl h2 { font-size: 2rem; }
  article#page .ttl h2 span { font-size: 1rem; } }

.arrow { position: relative; display: inline-block; padding: 0 0 0 16px; vertical-align: middle; text-decoration: none; font-size: 1rem; }
.arrow::after { position: absolute; top: 0; bottom: 0; margin: auto; content: ""; vertical-align: middle; right: 20px; width: 10px; height: 10px; border-top: 2px solid #fff; border-right: 2px solid #fff; -webkit-transform: rotate(45deg); transform: rotate(45deg); }

a.btn { color: #fff; background: #797979; padding: 0.5rem 0; }
a.btn:hover { filter: brightness(1.7); text-decoration: none; transition: 0.3s; }
a.btn.coming { background: #555; color: #ccc; }
a.btn.coming:hover { filter: none; text-decoration: none; }
a.btn.back.arrow::after { right: auto; left: 20px; width: 10px; height: 10px; border-top: 2px solid #fff; border-right: 2px solid #fff; transform: rotate(225deg); }
a.btn.black { background: #010002; }

#access, #limited, #alphapoint, #view, #limited-login, #concept-design, #outline, #company, #roomplan { padding: 6rem 0; }
@media screen and (max-width: 559px) { #access, #limited, #alphapoint, #view, #limited-login, #concept-design, #outline, #company, #roomplan { padding: 4rem 0; } }

#equipment { font-family: "Noto Serif JP", serif; margin-top: 5px; color: #fff; padding: 4rem 0; position: relative; /* 左側の巨大画像を2行分占有させる */ /* --- 【重要】グリッドブロック2：均等3列グリッド --- */ /* --- カード（共通コンポーネント） --- */ /* テキストエリアの装飾 */ }
#equipment::before { content: ""; width: 100%; height: 100%; display: block; z-index: -1; position: absolute; top: 0; right: 0; background: #010002; }
#equipment .caption { position: relative; }
#equipment .caption p.small { position: absolute; bottom: 0; font-size: 0.8rem; text-shadow: 1px 1px 2px #000, 1px 1px 10px #000; right: 5px; color: #fff; z-index: 2; }
#equipment .caption p.small.bk { color: #010002; text-shadow: none; }
@media screen and (max-width: 559px) { #equipment .caption p.small { font-size: 0.7rem; } }
#equipment ul.tab-nav { display: flex; justify-content: space-between; }
#equipment ul.tab-nav li { width: 18%; }
#equipment ul.tab-nav a { background: linear-gradient(to right, #797979 -10%, #000, #797979 110%); color: #fff; text-decoration: none; padding: 10px 20px; position: relative; display: block; width: 100%; }
#equipment ul.tab-nav a::after { content: ''; border: none; height: calc(100% + 6px); width: 100%; display: inline-block; position: absolute; background: linear-gradient(90deg, #797979 0%, #fff 54%, #c2c2c2 83%, #797979 100%); top: -3px; left: 0; bottom: auto; z-index: -1; }
#equipment ul.tab-nav a:hover { color: #010002; background: linear-gradient(to right, #ca9c2b, #ca9c2b, #fff9b1, #ca9c2b); transition: 0.3s; }
#equipment ul.tab-nav a.is-active { background: linear-gradient(to right, #ca9c2b, #ca9c2b, #fff9b1, #ca9c2b); color: #010002; }
@media screen and (max-width: 768px) { #equipment ul.tab-nav { flex-wrap: wrap; justify-content: space-around; }
  #equipment ul.tab-nav li { width: 30%; }
  #equipment ul.tab-nav li:nth-child(4), #equipment ul.tab-nav li:nth-child(5) { margin-top: 1rem; } }
@media screen and (max-width: 559px) { #equipment ul.tab-nav { flex-wrap: wrap; justify-content: space-around; }
  #equipment ul.tab-nav li { width: 47%; }
  #equipment ul.tab-nav li:nth-child(3) { margin-top: 1rem; } }
#equipment .content { text-align: left; }
#equipment hr { display: block; height: 2px; margin: 0; background: linear-gradient(90deg, #797979 0%, #fff 54%, #c2c2c2 83%, #797979 100%); }
#equipment .tab-item.is-active { background-color: #f1df91; /* ゴールド */ color: #000; border-bottom: 1px solid transparent; }
#equipment h3.title { color: #d39f2a; text-align: center; font-size: clamp(1.8rem, 9vw, 3rem); margin-top: 3rem; }
#equipment .subtitle { text-align: center; font-size: clamp(1rem, 5vw, 1.6rem); }
@media screen and (max-width: 768px) { #equipment .subtitle { text-align: left; line-height: 1.6; } }
#equipment .grid-top-block { margin-top: 4rem; display: grid; /* 左は2/3幅（2fr）、右は1/3幅（1fr）の2列。gapは20px */ grid-template-columns: 2fr 1fr; gap: 4rem; }
#equipment .grid-12-block { margin-top: 4rem; display: grid; /* 左は2/3幅（2fr）、右は1/3幅（1fr）の2列。gapは20px */ grid-template-columns: 1fr 2fr; gap: 4rem; }
#equipment .main-image { grid-row: span 2; }
#equipment .main-image img { width: 100%; height: 100%; }
#equipment .grid-uniform-block { display: grid; /* 均等な3列。gapは20px */ grid-template-columns: repeat(3, 1fr); margin-top: 4rem; gap: 4rem; }
#equipment .card .img-wrap img { width: 100%; height: 100%; }
#equipment .card-info { padding: 10px 0; }
#equipment .card-title { font-size: 1.2rem; text-align: center; }
#equipment .card-text { font-size: 1rem; margin-top: 0.8rem; line-height: 1.6; }
#equipment .card-text .small { font-size: 0.8rem; }
#equipment .full-images { margin-top: 2rem; }
#equipment .full-images + hr { margin-top: 4rem; }
#equipment .full-images .card-text { text-align: center; }
#equipment .full-images.zeh-block { position: relative; }
#equipment .full-images.zeh-block img { margin-top: -10rem; }
#equipment .full-images.support { background: #fff; position: relative; }
#equipment .full-images.support::after { content: ''; border: none; height: calc(100% + 10px); width: 100%; display: inline-block; position: absolute; background: linear-gradient(to right, #ca9c2b, #ca9c2b, #fff9b1, #ca9c2b); top: -5px; left: 0; bottom: auto; z-index: -1; }
#equipment .full-images .link-box { padding: 4rem 20px; background: #fff; }
#equipment .full-images .link-box a { max-width: 400px; display: block; margin: 0 auto; }
#equipment .full-images .link-box a:hover { opacity: 0.5; transition: 0.3; }
#equipment .full-images .link-box p.small { color: #010002; margin-top: 2rem; }
@media screen and (max-width: 559px) { #equipment .full-images .link-box { padding: 2rem 20px; } }
@media screen and (max-width: 768px) { #equipment .full-images .card-text { text-align: left; } }
#equipment .block { margin-top: 4rem; }
@media screen and (max-width: 559px) { #equipment .block { margin-top: 2rem; } }
@media screen and (max-width: 559px) { #equipment { /* 【上部ブロック】 2列 → 縦1列に変更 */ }
  #equipment .grid-top-block { grid-template-columns: 1fr; gap: 0px; /* スマホ用に余白を少し狭める */ margin-top: 2rem; }
  #equipment .main-image { grid-row: auto; }
  #equipment .grid-uniform-block, #equipment .grid-12-block { grid-template-columns: 1fr; gap: 0px; margin: 0; }
  #equipment .img-wrap img { margin-top: 2rem; } }
@media screen and (max-width: 768px) { #equipment h3 { font-size: 4vw; } }
@media screen and (max-width: 768px) { #equipment h3 { font-size: 5vw; } }

#equipment.security ul.tab-nav li { width: 24%; }
@media screen and (max-width: 768px) { #equipment.security ul.tab-nav { justify-content: space-between; }
  #equipment.security ul.tab-nav li { width: 48%; }
  #equipment.security ul.tab-nav li:nth-child(4), #equipment.security ul.tab-nav li:nth-child(3) { margin-top: 1rem; } }
#equipment.security .zeh-bg { height: 100vh; width: 100%; position: relative; margin-top: 4rem; background: url("../../images/equipment/zeh_bg.jpg") center bottom/cover; }
#equipment.security .zeh-bg img.zeh-ttl { position: absolute; max-width: 500px; top: 0; right: 0; bottom: 0; left: 0; margin: auto; }
@media screen and (max-width: 768px) { #equipment.security .zeh-bg { height: 80vh; }
  #equipment.security .zeh-bg img.zeh-ttl { max-width: auto; width: 80%; top: 6rem; bottom: auto; } }
