@charset "UTF-8";
@import url("/ir/dao/css/color.css");  /* 株主DAO用カラー変数 */

.pc-view {
    display: block;
}
.sp-view {
    display: none;
}

.mt10 {
    margin-top: 10px;
}

.mt30 {
    margin-top: 30px;
}

#main p {
    font-size: unset;
    line-height: unset;
    margin: unset;
}

#main article {
    max-width: 700px;
    width: 100%;
    color: #666;
}

#main h1 {
    font-size: 30px;
    margin: 0 0 20px 30px;
}

#main ul.notes {
    margin-top: 8px;
    margin-left: 30px;
}

#main ul.notes li {
    font-size: 14px;
    line-height: 160%;
    text-indent: -14px;
    margin-left: 16px;
}

#fv {
    margin-left: 30px;
    max-width: 670px;
}

#fv p img {
    width: 100%;
    height: auto;
}

/*
#main .ttl-s {
    padding-top:44px;
    padding-bottom: 5px;
    font-size: 16px;
}

#main .ttl-m {
    font-size: 22px;
    padding-bottom: 8px;
}

#main .ttl-m span {
    font-size: 18px;
}

#main .ttl-l {
    font-size: 30px;
    font-weight: bold;
    color: var(--themeColor);
    display: inline;
    background-image: linear-gradient(to bottom, transparent 50%, yellow 50%);
    background-size: 100% 100%;
    background-repeat: no-repeat;
}

#main .ttl-l span.ttl-point {
    font-size: 24px;
    font-weight: normal;
}

#main .ttl-l span.ttl-num {
    font-size: 44px;
    font-family: "din-2014", sans-serif;
    font-weight: normal;
    font-style: normal;
    padding-top: 10px;
}
*/

#main #benefit p {
    margin-left: 30px;
}

#main #benefit p.benefit-point {
    margin: 34px 0 10px 30px;
    color: var(--themeColor);
}

.point-table {
  width: 100%;
  max-width: 670px;
  border-collapse: separate;
  border-spacing: 0;
  margin: 0 0 0 30px;
  border: 1px solid var(--themeColor);
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  overflow: hidden;
}

.point-table thead {
  background-color: var(--themeColor);
  color: white;
}

.point-table thead th {
  padding: 12px;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  border-right: 1px solid #fff;
}

.point-table thead th:last-child {
    border-right: none;
}

.point-table tbody td {
  padding: 16px;
  font-size: 16px;
  text-align: center;
  color: #666;
}

.point-table tbody tr.alt-row {
  background-color: #f9f9f9;
}

.point-table td.highlight {
  color: var(--themeColor);
  font-weight: bold;
}

/* プレミア優待クラブボタンここから */

.button-wrapper {
  text-align: center;
  margin: 40px 0 0 30px;
}

.premium-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  padding: 1em 2em;
  background-color: var(--themeColor);
  color: #fff;
  text-decoration: none;
  font-weight: bold;
  font-size: 16px;
  border: none;
  border-radius: 999px; /* pill shape */
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
  transition: opacity 0.3s ease, transform 0.2s ease;
  letter-spacing: 0.08rem;
}

.premium-button:hover {
    opacity: 0.8;
    transform: translateY(1px);
    color: #fff;
}

.premium-button .arrow-icon {
  width: 1em;
  height: 1em;
  flex-shrink: 0;
}

/* プレミア優待クラブボタンここまで */


#main .goods {
    background: #FFE4E5;
    border-radius: 10px;
    padding: 20px;
    margin: 60px 0 0 30px;
}

#main #benefit .goods-ttl {
    font-size: 20px;
    font-weight: bold;
    padding: 20px 0 30px;
    margin-left: 0;
    text-align: center;
}

#main #benefit .goods-txt {
    line-height: 160%;
}

.highlight-banner {
  background-color: #ffe6e6; /* 薄いピンク背景 */
  color: var(--themeColor);
  font-weight: bold;
  font-size: 16px;
  padding: 12px 20px;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5em;
  margin-top: 24px;
}

.highlight-banner .slash {
  font-size: 20px;
  line-height: 1;
}

.highlight-banner .text {
  white-space: nowrap;
}

.goods-img {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.goods-img li {
    width: 152px;
    height: auto;
}

.goods-img li img {
    width: 100%;
    border-radius: 4px;
}

/*.ご利用の流れ */

#main #flow,
#main #subject,
#main #schedule,
#main #attention {
    margin-top: 80px;
}

#main #flow .flow-number {
    margin-left: 30px;
    display: flex;
    justify-content: space-between;
    align-items: top;
    padding-bottom: 16px;
    border-bottom: 1px dotted var(--themeColor);
}

#main #flow .flow-detail {
    margin-top: 16px;
}

#main #flow .flow-detail ul li.flow-ttl {
    font-size: 20px;
    padding: 10px 0 10px 48px;
}

#main #flow .flow-detail ul li.flow-ttl > span {
    color: var(--themeColor);
}

#main #flow .flow-detail ul li.flow-ttl.number01 {
    background: url(/ir/dao/images/benefitplan/flow_number01.svg) no-repeat left;
}

#main #flow .flow-detail ul li.flow-ttl.number02 {
    background: url(/ir/dao/images/benefitplan/flow_number02.svg) no-repeat left;
}

#main #flow .flow-detail ul li.flow-ttl.number03 {
    background: url(/ir/dao/images/benefitplan/flow_number03.svg) no-repeat left;
}

#main #flow .flow-detail ul li.flow-ttl.number04 {
    background: url(/ir/dao/images/benefitplan/flow_number04.svg) no-repeat left;
}

#main #flow .flow-detail ul li.flow-ttl.number04.pr10 {
    padding-right: 10px;
}

#main #flow .flow-detail ul li.flow-notes {
    margin-top: 8px;
    font-size: 14px;
}

#main #flow .flow-number p.flow-img01 {
    width: 200px;
    height: auto;
    padding: 16px 16px 0;
}

#main #flow .flow-number p.flow-img02 {
    width: 200px;
    height: auto;
    padding: 16px 16px 0;
}

#main #flow .flow-number p.flow-img03 {
    width: 200px;
    height: auto;
    padding: 36px 16px 0;
}


#main #flow .flow-number p.flow-img04 {
    width: 280px;
    height: auto;
    padding: 36px 8px 0 24px;
}

#main #flow .flow-number p.flow-img01 img,
#main #flow .flow-number p.flow-img02 img,
#main #flow .flow-number p.flow-img03 img,
#main #flow .flow-number p.flow-img04 img {
    width: 100%;
}


/*.対象となる株主様 */

#main #subject p.txt {
    margin-left: 30px;
    margin-bottom: 16px;
}

.subject-flame {
    margin-left: 30px;
}

.subject-flame li.subject-flame-line {
    border: 1px solid #ccc;
    padding: 16px;
    margin-bottom: 16px;
}

.subject-flame li.subject-flame-line p span {
    color: var(--themeColor);
}

.subject-flame .subject-notice {
    font-size: 14px;
    margin-top: 16px;
    text-indent: -14px;
    margin-left: 16px;
}


/* 年間スケジュール */

#main #schedule .schedule-bg {
    background: url(/ir/dao/images/benefitplan/schedule_bg.png) no-repeat top right / 620px auto;
    margin: 57px 0  0 30px;
    position: relative;
    height: 760px;
}

#main #schedule .schedule-bg p,
#main #schedule .schedule-bg ul {
    text-align: center;
    position: absolute;
}

.schedule-vesting {
    top: -30px;
    right: 40px;
}

.schedule-vesting-img {
    top: -20px;
    left: 350px;
}

.schedule-point01 {
    top: 80px;
    left: 230px;
}

.schedule-point01 li {
    margin-bottom: 12px;
}

li.schedule-day {
    background-color: #fff;
    border-radius: 20px;
    padding: 4px 10px;
}

li.schedule-day sup {
    font-size: 0.7em;
    vertical-align: super;
}

.schedule-info-img {
    top: 166px;
    left: 324px;
}

#main .schedule-info {
    top: 230px;
    left: 118px;
    line-height: 160%;
}

.schedule-exchange01 {
    top: 340px;
    left: 66px;
}

.schedule-exchange02 {
    top: 520px;
    left: 55px;
}

.schedule-point02 {
    top: 430px;
    right: 36px;
}

.schedule-exchange01 li:nth-child(1),
.schedule-exchange01 li:nth-child(4),
.schedule-exchange02 li:nth-child(1),
.schedule-exchange02 li:nth-child(4),
.schedule-point02 li:nth-child(1) {
    line-height: 180%;
}

.schedule-exchange01 li:nth-child(3),
.schedule-exchange02 li:nth-child(3),
.schedule-point02 li:nth-child(3) {
    margin-top: 12px;
}

.schedule-notes {
    font-size: 12px;
}

.schedule-date {
    top: 20px;
    left: -16px;
}

#main .schedule-open {
    bottom: 5px;
    left: 270px;
    font-size: 16px;
}

/* 申し込み期間について */

#schedule .request {
    margin-left: 30px;
    background: #F8F8F8;
    padding: 24px;
}

#schedule .request dl {
    margin-bottom: 48px;
}

#schedule .request dl:last-child {
    margin-bottom: 0;
}

#schedule .request dl dt {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 8px;
}

#schedule .request dl dd {
    line-height: 170%;
}

#schedule .request dl dd a,
#main #flow .flow-detail ul li.flow-notes a {
    color: #0000FF;
    text-decoration: underline;
}

#schedule .request dl dd a:hover,
#main #flow .flow-detail ul li.flow-notes a:hover {
    text-decoration: none;
}

#schedule .request dl dd.request-notes {
    font-size: 14px;
}

#schedule .request dl span {
    color: var(--themeColor);
}

#schedule .request .request-list {
    text-indent: -16px;
    margin-left: 16px;
    margin-bottom: 8px;
}

/* 留意事項 */

#main #attention h3::before {
    content: unset;
}

#main #attention dl {
    margin-left: 30px;
    margin-bottom: 40px;
}

#main #attention dl dt {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 8px;
}

#main #attention dl dd {
    line-height: 180%;
}

#main #attention dl dd span {
    color: var(--themeColor);
}

#main #attention dl dd span.attention-b {
    color: #666;
    font-weight: bold;
}



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

    .sp-view {
        display: block;
    }

    #main h1 {
    font-size: 24px;
    margin: 0 0 30px 0;
    }


    #fv {
    margin-left: 0;
    }

    /*
    #main .ttl-s {
        font-size: 14px;
        padding-top: 34px;
    }

    #main .ttl-m {
        font-size: 18px;
        font-weight: bold;
        padding-bottom: 0;
    }

    #main .ttl-m span {
        display: none;
    }
    */

    .point-table {
        margin: 0;
    }

    .point-table thead th {
        font-size: 13px;
    }

    #main ul.notes {
        margin-left: 0;
    }

    .button-wrapper {
        margin: 40px 0 0 0;
    }

    .premium-button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5em;
    padding: 1em 1em 1em 4em;
    background-color: var(--themeColor);
    color: #fff;
    text-decoration: none;
    font-weight: bold;
    font-size: 16px;
    border: none;
    border-radius: 999px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
    transition: opacity 0.3s ease, transform 0.2s ease;
    letter-spacing: 0.08rem;
    width: 100%;
    }

    .premium-button .arrow-icon {
    width: 24px;   /* サイズアップ */
    height: 24px;
    flex-shrink: 0; /* 折り返し防止 */
    }

    #main .goods {
        margin: 60px 0 0 0;
        padding: 20px 18px;
    }

    .highlight-banner {
        padding: 12px 0;
        font-size: 15px;
    }

    .highlight-banner .text {
        white-space: unset;
    }
    
    .goods-img li {
        width: 48%;
        margin-bottom: 6px;
    }

    #main #flow .flow-number {
        margin-left: 0;
        display: block;
        justify-content: unset;
    }

    #main #flow .flow-number p.flow-img01,
    #main #flow .flow-number p.flow-img02,
    #main #flow .flow-number p.flow-img03,
    #main #flow .flow-number p.flow-img04 {
        text-align: center;
        width: 100%;
    }

    #main #flow .flow-number p.flow-img01 img,
    #main #flow .flow-number p.flow-img02 img,
    #main #flow .flow-number p.flow-img03 img,
    #main #flow .flow-number p.flow-img04 img {
        display: block;
        margin: auto;
        width: 200px;
        height: auto;
    }

    .subject-flame {
        margin-left: 0;
    }

    #schedule .request {
        margin-left: 0;
    }

    #main #attention dl {
        margin-left: 0;
    }

    .scroll-container {
    overflow-x: scroll;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    width: 100%;
    white-space: nowrap;
    position: relative;

    scrollbar-width: thin;
    scrollbar-color: #666 transparent;
    }

    .scroll-container::-webkit-scrollbar {
    height: 6px;
    }

    .scroll-container::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 3px;
    }

    .scroll-container::-webkit-scrollbar-track {
    background: transparent;
    }

    .scroll-image {
    display: inline-block;
    width: 900px; /* 任意の画像幅 */
    height: auto;
    margin-right: 50px; /* ← 横スクロール後の余白（←追加ポイント） */
    }

    .scroll-link {
    position: absolute;
    top: 150px;
    left: 210px;
    width: 40px;  /* 任意サイズ */
    height: 40px;
    }

    /* ScrollHint 用のクラスを念のため指定 */
    .js-scrollable {
    display: block;
    }



    #main #mail {
        padding-top: 20px;
    }
    
    .sp-schedule-info {
    margin-top: 50px;
    border: 1px solid #666;
    border-radius: 10px;
    padding: 20px;
    position: relative;
    }

    .sp-schedule-icon {
    position: absolute;
    top: -46px;
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
    width: 60px;  /* ← 画像サイズと同じに合わせる */
    height: 60px;
    pointer-events: none; /* ← 必要であれば、クリックイベントを無効化 */
    }

    .sp-schedule-icon img {
    display: block;
    margin: auto;
    }

    #main #attention {
        margin-top: 60px;
    }
}