@charset "UTF-8";
.ps_color{
fill:#000000;
}

.news_time{
margin-top: 3rem;
}

.summary .place_container {
margin-bottom: 5rem;
}

.summary .news_container .line-container{
border: 4px #33a6dc solid;
background: #fff;
}

.summary .place .place_name {
background:#007ee4;
}

.modal-content{
border: solid rgba(0, 0, 0, 1.00) 5px;
border-image: linear-gradient(to right, #f4bdca, #e3e3e3ad, #9ed2e1) 5;
}

.lead-navy{
color: #240f00;}

.lead-bcm{
margin-bottom: 0rem;
}

.lead-line{
text-align: center;
margin-top: 4rem;
}

.bg-color{
  height: 100%;
  width: 100%;
 background-image: linear-gradient(90deg, #e1faff, #a2efff);
}

.ttl-g {
font-size: 3.2rem;
font-weight: bold;
letter-spacing: -0.015em;
display: flex;
justify-content: center; /* ← 全体を中央へ */
align-items: center;
gap: 0.6rem;
color: #ffa116;
margin-bottom: 6rem;
}

.ttl-g {
    font-size: 3rem;           /* スマホで見ても適切なサイズに微調整 */
    font-weight: 800;           /* より太くして力強さを出す */
    letter-spacing: 0.1em;      /* 文字の間隔を少し広げて読みやすく */
    text-align: center;
    color: #007ee4;             /* 信頼感のあるラムネブルー */
    margin-bottom: 5rem;
    position: relative;
    display: block;
}

/* 下線の装飾：視認性を邪魔せず、テーマ性を出す */
.ttl-g::after {
    content: '';
    position: absolute;
    bottom: -12px;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;                /* 短めの線にすることで、文字を際立たせる */
    height: 4px;
    background: #ffa116;        /* アクセントカラーで注目度を上げる */
    border-radius: 2px;
}

.ttl-icon{
    width: 1em;
    height: 1em;
}
.kabegami{
  background-image: url("/images/chiramune/bubble_01.webp");
  background-repeat: repeat;

  animation:
    bubble-up 45s linear infinite,
    bubble-sway 6s ease-in-out infinite;
}


.kabegami01 {
top:0;
left:0;
z-index:-1;
width:100%;
height:100%;
background-image: url("/images/chiramune/bubble_01.webp");
    background-size: 100%;
  animation:
    bubble-up 40s linear infinite,
    bubble-sway 6s ease-in-out infinite;
}

/* 上に流れる */
@keyframes bubble-up {
  from {
    background-position-y: 0;
  }
  to {
    background-position-y: -100%;
  }
}

/* 左右にふわふわ */
@keyframes bubble-sway {
  0% {
    background-position-x: 0;
  }
  50% {
    background-position-x: 30px;
  }
  100% {
    background-position-x: 0;
  }
}


.tbl{
margin-top: 4rem;
}

.red-bg{
color: red;
font-size:calc(1.4rem +(1vw - 0.32rem)* 0.3584);
}

.line-container{
background-size: 10%;
background-repeat: repeat-x;
color: #000000;
align-items: center;
gap: 20px;
backdrop-filter: blur(5px);
background-color: rgb(255 255 255 / 10%);
/*box-shadow: #39c5bc 7px 7px 15px;*/
border: 4px #007ee4 solid;
border-radius: 40px;
}

.line-container_tktn{
margin-top:5rem;
}

.ttl-d__text {
z-index: 5;
}

.info {
background:rgb(255 255 255 / 100%);
}

#header{
background: rgb(255 255 255);
border-bottom: solid 1px #CCC;
}

.header-item {
color: #000000;
}

.ttl-a,
.ttl-b:before,
.ttl-d__text:before,
.ttl-e
{
  background:#36a5ff;
}

.ttl-b,
.ttl-c,
.right-text{
  color: #000000;
}

.header-top__menu__list li a:hover {
  color: #18A5FF;
}

.ttl-b{
  position: relative;
  margin-bottom: 5rem;
  padding-bottom: 0.28em;
  font-size: 3.4rem;
  line-height: 1.076923;
  letter-spacing: 0.01em;
  font-weight: bold;
  border-bottom: solid 3px #cdcdcd;
  text-align: center;
}

.ttl-c{
	border: solid 2px #ff9daa;
	background-image:repeating-linear-gradient(135deg, transparent, transparent 8px, #F1F3FF 8px, #F1F3FF 12px);
}

.l-column.goods-list .goods-list__inner{
  background: #FFF;
  border-radius: 10px;
}

.image_boder{
  border: 7px #EBD8BB solid;
  border-bottom: 0px;
}

.caution-container{
  background: #FFF;
}

.l-column.goods-list .col-1 .image {
  padding-right: 2rem;
  border-right: dotted 3px #ff525d;
}

.space{
  color: #ddd;
  margin: 2rem 0;
}

.main section:nth-last-of-type(4) .inner{
margin: 0 auto 0rem;
}

.button .btn.btn-a{
    color: #ffffff;
    font-size: 1.6rem;
    background: #1a1a1a;
    border-radius: 5px;
    border: solid 3px #1a1a1a;
}

.button.button-online .btn.btn-a{
    color: rgb(255, 255, 255);
    font-size: 1.6rem;
    background: rgb(130 0 5);
    border-radius: 5px;
    border-width: 3px;
    border-style: solid;
    border-color: rgb(130 0 5);
    border-image: initial;
}

.button-online .btn.btn-a:hover{
    color: #111;
    background:#fff;
    border-color: rgb(130 0 5);
	opacity: 1;
}


@media only screen and (max-width: 599px){
.summary .place_container{
margin-bottom: 0rem;
}


.header-top__hamburger .bar{
background: #000000;
 }

.lead-line{
margin-top: 5rem;
 }

.line-container{
background-size: 19%;
 }

.kabegami01{
background-size: 160%;
 }
}


.contact{
background: #ffffff;
}

.item-tokuten{
margin-top: 5rem;
}






/* =============================================
   お知らせセクション
============================================= */
.news_container {
    position: relative;
    overflow: hidden;
    z-index: 1;
    background: rgba(255, 255, 255, 0.9);
    border-radius: 20px;
    padding: 7% 5%;
    margin: 0 auto;
    max-width: 800px;
    box-shadow: 0 8px 25px rgba(0, 126, 228, 0.1);
    backdrop-filter: blur(10px);
}

/* =============================================
   テキスト・コンテンツエリア
============================================= */
.news_info_block, 
.news_action_wrapper {
    position: relative;
    z-index: 2;
}

.news_info_block {
    text-align: center;
    margin-bottom: 40px;
}

.news_info_block .lead {
    font-size: 1.8rem;
    line-height: 1.8;
    font-weight: bold;
    color: #240f00;
}

.news_action_wrapper {
    display: flex;
    gap: 30px;
}

.action_item {
    flex: 1;
    text-align: center;
}

.action_note {
    font-size: 1.2rem;
    font-weight: bold;
    color: #007ee4;
    margin-bottom: 10px;
}

.action_note::before,
.action_note::after {
    content: '★';
    margin: 0 5px;
    font-size: 1rem;
    color: #ffa116;
    display: inline-block;
    animation: starTwinkle 1.5s infinite;
}

.action_sub_text {
    font-size: 1.4rem;
    color: #212121;
    margin-top: 8px;
    opacity: 0.8;
}

/* =============================================
   ボタンデザイン
============================================= */
.news_btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px 10px;
    border-radius: 12px;
    text-decoration: none !important;
    transition: all 0.3s ease;
    box-shadow: 0 4px 0 rgba(0,0,0,0.1);
}

.news_btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(0,0,0,0.1);
    opacity: 1;
}

.btn_main {
    font-size: 1.5rem;
    font-weight: bold;
    color: #fff;
}


.news_btn.onoden { background: #007ee4; }
.news_btn.online { background: #ffa116; }

/* =============================================
   背景装飾
============================================= */
.cheer-line {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 8px;
    background: repeating-linear-gradient(
        90deg,
        #007ee4,
        #007ee4 20px,
        #ffa116 20px,
        #ffa116 40px
    );
    opacity: 0.8;
    z-index: 1;
}

.bubble-element {
    position: absolute;
    background: rgba(255, 255, 255, 0.6);
    border: 1px solid rgba(0, 126, 228, 0.2);
    border-radius: 50%;
    z-index: 0;
    animation: floatBubble 6s infinite ease-in-out;
}

.b1 { width: 40px; height: 40px; top: 10%; left: 5%; animation-delay: 0s; }
.b2 { width: 20px; height: 20px; bottom: 15%; right: 10%; animation-delay: 2s; }
.b3 { width: 60px; height: 60px; bottom: -20px; left: 40%; opacity: 0.3; animation-delay: 4s; }

/* =============================================
   アニメーション定義
============================================= */
@keyframes floatBubble {
    0%, 100% { transform: translateY(0) translateX(0); }
    50% { transform: translateY(-20px) translateX(10px); }
}

@keyframes starTwinkle {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(0.8); }
}

/* =============================================
   スマホ
============================================= */
@media only screen and (max-width: 599px) {
    .news_container {
        border-radius: 15px;
    }

    .news_info_block .lead {
        font-size: 1.5rem;
        text-align: left;
    }

    .news_action_wrapper {
        flex-direction: column;
        gap: 25px;
    }

    .news_btn {
        padding: 20px 10px;
    }
    
    .action_note {
        font-size: 1.1rem;
    }

    .b3 {
        display: none;
    }
}
