
/* balianのticket_infoの構造をそのまま使ってます。色だけスポーツ用にネイビー基調にしてます */
*{margin:0;padding:0;box-sizing:border-box;}
html,body{width:100%;height:100%;}
img{width:100%;height:auto;vertical-align:top;}
ul{list-style:none;}
a{text-decoration:none;color:inherit;transition:color .2s,opacity .2s;}
a:hover{opacity:.78;}

:root{
  --gold:#e3c14a;
  --gold-d:#b8901e;
  --blue:#1f4aa0;
  --blue-d:#1c3a7a;
  --navy:#0a1530;
  --navy-2:#0d1b3d;
  --navy-deep:#060d1e;
  --light:#eef1f7;
  --text:#0b1a3a;
  --text-white:#eef2f9;
  --font-heading:"Noto Serif JP",serif;
  --font-body:"BIZ UDPGothic","Hiragino Kaku Gothic Pro","Yu Gothic",Meiryo,sans-serif;
  --font-num:"Cormorant Garamond",serif;
}
body{
  font-family:var(--font-body);
  background:var(--navy-deep);
  color:var(--text-white);
  line-height:1.6;
  word-wrap:break-word;
}
[id] {
  scroll-margin-top: 360px;
}

/* 全体ラッパー・背景・左ビジュアル・右枠まわりです */
.main-contents{position:relative;}
.cd-fixed-bg{
  position:relative;min-height:100%;height:100vh;
  background-color:var(--navy-deep);z-index:1;
}
/* PCの背景はmain_img01をフルで敷いてます */
.cd-fixed-bg.cd-bg-1{
  background:url("/images_2024r/sports/main_img01.png") center center/cover no-repeat;
  background-color:var(--navy-deep);
}

/* 左側のビジュアルです。スライドショーとロゴ・コピーが入ります */
.mv_visual{position:relative;}
.mv_slider{position:relative;width:100%;aspect-ratio:16/9;}
.slide{
  position:absolute;inset:0;background-size:contain;background-position:center;background-repeat:no-repeat;
  opacity:0;transition:opacity 1.2s ease;
}
.slide.is-active{opacity:1;}
.mv_link {
  position: absolute;
  inset: 0;
  display: none;
  z-index: 10;
}
.mv_caption{text-align:center;}
.mv_logo{width:200px;margin:0 auto 18px;display:block;}
.mv_copy{
  color:#fff;font-size:18px;font-weight:600;line-height:1.95;letter-spacing:1.5px;
  text-shadow:0 0 16px rgba(0,0,0,.55);
}
.mv_copy .accent{color:var(--gold);}

section{padding:60px 0;}
.section_inner{width:100%;max-width:300px;margin:auto;}

.caption_title{
  color:var(--gold);text-align:center;font-family:var(--font-body);
  font-size:13px;font-weight:400;line-height:2.28;letter-spacing:2.8px;text-transform:uppercase;
  position:relative;width:fit-content;margin:auto;
}
.caption_title::before,.caption_title::after{
  position:absolute;content:'◆';font-size:8px;color:var(--gold);top:50%;transform:translateY(-50%);opacity:.85;
}
.caption_title::before{left:-18px;}
.caption_title::after{right:-18px;}

.section_title{
  color:var(--text-white);text-align:center;
  font-size:24px;font-weight:600;line-height:1.4;margin:20px 0 80px;position:relative;
}
.section_title::after{
  position:absolute;content:"";left:50%;transform:translateX(-50%);bottom:-40px;width:30px;height:1px;background:var(--gold);
}
.section_lead{
  color:var(--text-white);text-align:center;font-family:var(--font-body);
  font-size:12px;font-weight:400;line-height:2;letter-spacing:1px;margin-top:30px;
}
ul.annotation{font-size:10px;font-family:var(--font-body);opacity:.85;}
ul.annotation li{padding-left:1em;text-indent:-1em;list-style:inside;list-style-type:'※';line-height:1.7;}

/* ここからPC向けです */
@media only screen and (min-width:1024px){
  .cd-fixed-bg{padding:5em 0;}
  /* 左ビジュアルは固定で置いてます */
  .mv_visual{
    position:absolute;left:0;top:0;width:48%;height:100vh;z-index:2;
    display:flex;flex-direction:column;justify-content:center;align-items:center;
    padding:60px 70px;gap:42px;
  }
  .mv_slider{max-width:560px;}
  .mv_copy{font-size:23px;}
  /* 右のスマホ枠です */
  .cd-scroll{
    width:390px;position:absolute;bottom:0;right:90px;z-index:3;
    overflow-y:auto;height:90vh;
    border-top-left-radius:20px;border-top-right-radius:20px;
    border:11px solid #fff;border-bottom:0;
  }
  .cd-scroll::-webkit-scrollbar{width:2px;}
  .cd-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.25);border-radius:5px;}
  .cd-scroll::-webkit-scrollbar-track{background:none;}
}
@media only screen and (min-width:1800px){
  .cd-scroll{right:12vw;}
}

/* ここからスマホ向けです。スライド→余白に文言→あとはセクション縦積みでお願いします */
@media only screen and (max-width:1023px){
  .cd-fixed-bg{height:auto;min-height:0;padding:0;}
  .cd-fixed-bg.cd-bg-1{background:var(--navy-deep);}
  .mv_visual{width:100%;}
  .mv_slider{aspect-ratio:16/10;background:var(--navy-deep);}
  .mv_caption{padding:38px 24px 52px;background:var(--navy-deep);}
  .cd-scroll{width:100%;}
}

/* おすすめポイント */
.point-section{background:var(--navy);}
.point-section .caption_title{margin-bottom:42px;}
.box_point + .box_point{margin-top:34px;}
.point_img{border-radius:8px;overflow:hidden;}
.point_img img{aspect-ratio:4/3;object-fit:cover;}
.point_no{font-family:var(--font-num);font-style:italic;font-size:34px;color:var(--gold);line-height:1;margin:16px 0 6px;}
.point_title{font-family:var(--font-body);font-size:16px;font-weight:700;line-height:1.5;letter-spacing:1.2px;color:var(--text-white);}
.point_desc{font-family:var(--font-body);font-size:11px;font-weight:400;line-height:1.9;letter-spacing:.5px;color:#b7c1d6;margin-top:10px;}

/* パック料金。ここだけ背景を明るくして抑揚つけてます */
.plan-section{background:var(--light);}
.plan-section .section_title{color:var(--text);}
.plan-section .section_title::after{background:var(--gold-d);}
.plan-section .section_lead{color:var(--text);}
.box_plan{background:#fff;border-radius:10px;padding:24px 22px;box-shadow:0 4px 14px rgba(11,26,58,.12);color:var(--text);font-family:var(--font-body);}
.box_plan + .box_plan{margin-top:18px;}
.plan_tag{font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:1px;color:#fff;background:var(--blue-d);border-radius:14px;padding:5px 14px;width:fit-content;line-height:1;}
.plan_name{font-family:var(--font-heading);font-size:18px;font-weight:600;margin:14px 0 4px;letter-spacing:1px;}
.plan_note_in{font-size:10px;color:#5d6680;margin-bottom:14px;line-height:1.8;}
.plan_row{display:flex;justify-content:space-between;align-items:flex-end;padding:12px 0;border-top:1px dotted #c2cad9;}
.plan_row_label{font-size:11px;line-height:1.6;}
.plan_row_label small{display:block;color:#7a8298;font-size:9px;}
.plan_price{font-family:var(--font-num);font-weight:600;font-size:24px;color:var(--blue-d);line-height:1;white-space:nowrap;}
.plan_price small{font-family:var(--font-body);font-size:10px;}
.box_plan .annotation{margin-top:12px;color:#5d6680;}

/* 放映スケジュール。sports_scheduleの上部を移植してます */
.schedule-section{background:var(--navy);}
.sch_search{background:var(--navy-2);border:1px solid rgba(227,193,74,.28);border-radius:10px;padding:20px;margin-top:36px;font-family:var(--font-body);}
.sch_field + .sch_field{margin-top:14px;}
.sch_field label{display:block;font-size:11px;color:var(--gold);letter-spacing:1px;margin-bottom:6px;}
.sch_field select{width:100%;background:var(--navy-deep);color:var(--text-white);border:1px solid rgba(255,255,255,.18);border-radius:5px;padding:10px 12px;font-size:13px;font-family:var(--font-body);}
.sch_btn{width:100%;margin-top:18px;background:var(--gold);color:#1c1404;border:none;border-radius:5px;font-family:var(--font-heading);font-weight:600;font-size:14px;letter-spacing:2px;padding:12px;cursor:pointer;transition:.2s;}
.sch_btn:hover{background:#eccd60;}
.sch_list{margin-top:26px;display:flex;flex-direction:column;gap:12px;}
.sch_item{background:var(--navy-2);border-radius:8px;border-left:3px solid var(--gold);padding:14px 16px;font-family:var(--font-body);}
.sch_item_top{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.sch_date{font-size:13px;font-weight:700;color:var(--text-white);letter-spacing:.5px;}
.sch_genre{font-size:10px;color:var(--gold);border:1px solid var(--gold);border-radius:10px;padding:2px 9px;line-height:1.4;}
.sch_match{font-size:12px;color:#b7c1d6;line-height:1.5;}
.sch_note{font-size:10px;color:#8a93ab;margin-top:14px;font-family:var(--font-body);line-height:1.7;}
.sch_channels{margin-top:26px;text-align:center;font-family:var(--font-body);font-size:10px;color:#8a93ab;}
.sch_channels img{width:auto;height:34px;margin:8px auto 0;display:block;}
.sch_links{margin-top:22px;display:flex;flex-direction:column;gap:10px;}
.sch_links a{font-family:var(--font-heading);font-size:12px;font-weight:600;letter-spacing:1px;text-align:center;border:1px solid var(--gold);color:var(--gold);padding:11px;border-radius:4px;transition:.2s;}
.sch_links a:hover{background:var(--gold);color:#1c1404;opacity:1;}

/* 店舗情報 */
.shop-section{background:var(--navy-2);}
.area{margin-top:40px;}
.area_name{font-family:var(--font-heading);font-size:16px;font-weight:600;letter-spacing:1.5px;display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid rgba(227,193,74,.28);margin-bottom:20px;color:var(--text-white);}
.area_name::before{content:"";width:5px;height:16px;background:var(--gold);}
.box_shop{background:#fff;border-radius:10px;overflow:hidden;color:var(--text);font-family:var(--font-body);box-shadow:0 2px 8px rgba(0,0,0,.3);}
.box_shop + .box_shop{margin-top:16px;}
.shop_thumb{position:relative;}
.shop_thumb img{aspect-ratio:16/10;object-fit:cover;}
.shop_type{position:absolute;top:10px;left:10px;font-size:10px;font-weight:700;letter-spacing:1px;background:rgba(10,21,48,.88);color:var(--gold);padding:4px 12px;border-radius:3px;}
.shop_body{padding:18px;}
.shop_name{font-family:var(--font-heading);font-size:15px;font-weight:600;line-height:1.45;letter-spacing:.5px;}
.shop_tel{display:block;font-family:var(--font-num);font-weight:600;font-size:22px;color:var(--blue-d);margin:8px 0 14px;letter-spacing:1px;}
.shop_btns{display:flex;flex-wrap:wrap;gap:7px;}
.shop_btns a{flex:1;min-width:calc(50% - 4px);text-align:center;font-size:11px;font-weight:700;border:1px solid #c2cad9;border-radius:4px;padding:9px 6px;white-space:nowrap;color:var(--text);}
.shop_btns a.primary{background:var(--blue-d);color:#fff;border-color:var(--blue-d);}
.shop_note{font-size:10px;color:#b7c1d6;text-align:center;margin-top:24px;font-family:var(--font-body);line-height:1.8;}

/* フッター */
.footer-scroll{background:var(--navy-deep);padding:44px 0;}
.footer_nav{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;font-family:var(--font-body);}
.footer_nav a{color:var(--text-white);font-size:12px;}
.footer_logo{width:150px;margin:24px auto 16px;display:block;}
.footer_copy{text-align:center;font-size:10px;color:#5d6680;font-family:var(--font-body);letter-spacing:.5px;}

/* ハンバーガーメニュー（スマホ枠の上部に固定） */
.sp-headbar{position:sticky;top:0;z-index:20;}
.sp-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:rgba(6,13,30,.94);backdrop-filter:blur(6px);border-bottom:1px solid rgba(227,193,74,.2);}
.sp-header_logo img{width:118px;height:auto;display:block;}
.sp-header_toggle{width:30px;height:22px;position:relative;background:none;border:none;cursor:pointer;padding:0;}
.sp-header_toggle span{position:absolute;left:0;width:100%;height:2px;background:var(--gold);border-radius:2px;transition:.3s;}
.sp-header_toggle span:nth-child(1){top:0;}
.sp-header_toggle span:nth-child(2){top:10px;}
.sp-header_toggle span:nth-child(3){top:20px;}
.sp-header_toggle.is-open span:nth-child(1){top:10px;transform:rotate(45deg);}
.sp-header_toggle.is-open span:nth-child(2){opacity:0;}
.sp-header_toggle.is-open span:nth-child(3){top:10px;transform:rotate(-45deg);}
.sp-nav{background:rgba(6,13,30,.98);max-height:0;overflow:hidden;transition:max-height .35s ease;}
.sp-nav.is-open{max-height:75vh;overflow-y:auto;}
.sp-nav ul{padding:8px 24px;}
.sp-nav li{border-bottom:1px solid rgba(227,193,74,.16);}
.sp-nav a{display:block;padding:16px 4px;font-family:var(--font-heading);font-size:15px;font-weight:600;letter-spacing:1px;color:var(--text-white);}
.sp-nav a:hover{color:var(--gold);opacity:1;}
.sp-nav .nav_sub{padding-top:6px;padding-bottom:24px;}
.sp-nav .nav_sub li{border-bottom:none;}
.sp-nav .nav_sub a{padding:10px 4px;font-family:var(--font-body);font-size:12px;color:#b7c1d6;}