:root{
  --color-text-base: #002349;
  --color-text-sub: #7FBFF5;
  --color-text-inverse: #ffffff;
  --color-text-blue: #005baa;
  --color-bg-base: #ffffff;
  --color-bg-soft: #FBF8F8;
  --color-bg-dark: #002349;
  --header-height: 150px;
  --space-section: clamp(40px, 8vw, 100px);
  --color-accent-yellow: #F5C641;
  --color-accent-red:#E25C5F;
}


* {
    box-sizing: border-box;
}

body, p {
    font-size: 14px;
    line-height: 1.42857143;
    
}
@font-face {
    font-family: 'Poppins';
    src: url('/user_data/packages/default/img/common/Poppins-Bold.woff2') format('woff2'),
         url('/user_data/packages/default/img/common/Poppins-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}


html {
    font-size: 10px;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    font-family: sans-serif;
    line-height: 1.15;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    margin: 0;
    padding: 0;
    font-family: "Noto Sans JP", "Noto Sans CJK JP", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
}
body {
    color: #002349;
    transition: z-index 0ms 5.28455ms;
    background: #f6f6f6;
    margin: 0;
    padding: 0;
    padding-top: 48px;
}

.ec-searchnavRole,
.ec-layoutRole .ec-layoutRole__contents{
	max-width:none;
  padding-inline: 0;
  color: #002349;
}

a{
    text-decoration: none;
}

a:active, a:hover {
    outline-width: 0;
}
a:active, a:hover {
    outline: 0;
}

img {
    vertical-align: middle;
}

ul, li {
    list-style: none;
    padding: 0px;
    margin: 0px;
}
.pc_disp{
    display: block;
}
.sp_disp{
    display: none;
}


#topInfo p.time {
    background: #002349;
    color: #fff;
    height: 50px;
    width: 100%;
    position: fixed;
    font-size: 14px;
    padding: 0 8px;
    text-align: center;
    line-height: 50px;
    font-weight: bold;
    letter-spacing: 0.05em;
    top: 0px;
    margin: 0;
    z-index: 100;
}


.l-container{
  --container: 1200px;
  width: min(var(--container), 100% - 40px);
  margin-inline: auto;
}

.u-en{
  font-family: 'Poppins';
  font-weight: 600;
  letter-spacing: 0.08em;
}

.u-red{
color: var(--color-accent-red);
}

.u-em {
  font-size: 1.4em;
  font-weight: 900;
}

.u-offset-header{
  margin-top: var(--header-height);
}

.u-bg-white{
	background: #fff;
}

.u-text-sub{
  color: var(--color-text-sub);
}
.u-text-blue{
	color: var(--color-text-blue); ;
}

.u-text-center {
  text-align: center !important;
}

.u-text-right {
  text-align: right !important;
}

.section{
  padding-block: var(--space-section);
  scroll-margin-top: 60px;
}

.section--mb00{
	padding-bottom: 0px;
}


.section--dark{
	background:var(--color-bg-dark);
	color: var(--color-text-inverse);
}

.section--soft{
	background:var(--color-bg-soft);
}

.u-mt-20 {
  margin-top: 20px;
}

.u-mt-40 {
  margin-top: 40px;
}
.u-mb-40 {
    margin-bottom: 40px;
}

.ec-searchnavRole img {
    width: 100%;
    height: auto;
}

.c-heading--center{
	text-align: center;
}

.c-heading__sub{
	display: block;
	font-size: 16px;
	line-height: 2;
}

.c-heading__title{
	font-size: clamp(22px, 3vw, 36px);
	font-feature-settings: "palt";
	letter-spacing: 0.12em;
	line-height: 2;
	font-weight: 700;
	display: inline-block;
}

.section__text{
  line-height:1.9;
  font-size: clamp(14px, 3vw, 18px);
  letter-spacing: 0.05em;
  font-weight: 600;
  margin-block:40px 40px;
}

.section__text--center{
  text-align:center;
}

.section__text--catch {
   font-size: clamp(18px, 4vw, 28px);
  font-weight: 800;
  margin: 40px auto 20px;
}

.c-btnArea{
    margin-top: 60px;
    display: flex;
    justify-content: center;
    width: 100%; 
}

.c-btn {
	display: inline-flex;
	justify-content: center;
  align-items: center;
  min-height: 60px;
  padding-inline: 40px;
  border-radius: 999px;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  font-size: clamp(14px, 3vw, 18px);
	letter-spacing: 0.05em;
	transition: 0.5s;
}

.c-btn--blue{
  background:#0b2a4a;
  color: #fff;
}


.c-btn--small {
  min-height: 48px;
  padding-inline: 24px;
  font-size: 14px;
}

.c-btn--outline {
	border: 1px solid #0b2a4a;
	color: #0b2a4a;
	background: #fff;
}



.c-btn:hover{
	text-decoration:none;
	background: var(--color-bg-dark);
	color: var(--color-text-inverse);
}

.c-btn--blue:hover{
  background:#fff;
  color: #0b2a4a;
  border: 1px solid #0b2a4a;
}



.c-btn--fill {
  background: #0b5aa6;
  color: #fff !important;
  border: 1px solid #0b5aa6;
}

.c-heading--line .c-heading__title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
}

.c-heading--line .c-heading__title::before,
.c-heading--line .c-heading__title::after {
  content: "";
  flex: 1;
  height: 1px;
  background: #0b2a4a;
  max-width: 60px; /* テキストの近くに留める */
}

.c-heading--line .c-heading__title::before,
.c-heading--line .c-heading__title::after {
  margin-top: 0em;
}

.c-heading--line .c-heading__title::before {
  transform: rotate(70deg);
}
.c-heading--line .c-heading__title::after {
  transform: rotate(-70deg);
}


@media screen and (min-width: 768px){

 
#topInfo span {
    font-size: 24px;
}


#main-content picture img {
    width: 100%;
    height: auto;
}

#main-content{
    max-width: 100%;
    margin: 0 auto;
    overflow: hidden;
}
.mt00 {
    margin-top: 0 !important;
}
.ec-layoutRole .ec-layoutRole__header {
    height: auto;
    position: fixed;
    width: 100%;
    min-width: 1040px;
    top: 0;
    left: 0;
    z-index: 20;
}


#headNav{
	top: 60px;
	position: fixed;
	width: 1200px;
	left: 50%;
	margin: 0 auto;
	margin-left:-600px;
	height: 70px;
  background: #faf8f8;
	box-shadow: 0px 3px 20px #5253531A;
	border-radius: 35px;
	opacity: 1;
  z-index: 50;
  
}


  .c-header__pc::before {
        -webkit-backdrop-filter: blur(20px);
        backdrop-filter: blur(20px);
        max-width: 1200px;
        background-color: #ffffff1a;
        content: "";
        display: block;
        height: 40px;
        position: fixed;
        /* top: -1rem; */
        width: 100%;
        z-index: 10;
        margin: 0 auto;
        left: 50%;
    transform: translateX(-50%);
  }
  
  #headNav h1{
    position: absolute;
    display: block;
    margin: 0px;
    width: 158px;
    top: 50%;
    transform: translateY(-50%);
    left: 50px;
    height: 46px;
    z-index: 2;
  }

  #headNav h1 a img{
    vertical-align: initial;
  }
  
  .menu {
  display: flex;
  position: relative;
  padding-left: 230px;
  justify-content:flex-start;
  }

  .menu .menu_list{
  position: relative;
  }
  
  .menu .menu_list > a,
  .menu .single > a,
  .menu .menu_list01 > a,
  .menu .menu_list02 > a,
  .menu .menu_list03 > a   {
  display: block;
  padding: 0px 6px;
  text-align: center;
  font-size: 14px;
  height: 70px;
  line-height: 70px;
  text-decoration: none;
  overflow: hidden;
  color:#002238;
  font-weight: 400;
  position: relative;
  }
  
  .menu a:focus{
	border-radius: 0 !important;
  }
  
  .menu .icon > a{
	display: block;
	height: 70px;
	line-height: 70px;
	overflow: hidden;
	position: relative;
	width: 70px;
  text-align: center;
	text-indent: 100%;
  }
  
  .menu .icon > a span{
    display: none;
  }
.menu > li:nth-child(4){
  padding-left: 20px;
}

.menu > li:nth-child(5) {
  margin-left: auto;
}
.menu > li:nth-child(7) {
  margin-right: 30px;
}
  
  .menu .icon.cart a{
	width: 80px;
  }
  
  
  .menu .icon.login a:before {
	content:"";
	position: absolute;
	width: 24px;
	height: 24px;
	top:22px;
	left: 24px;
	display: block;
	background:url(/html/template/sodastream/assets/img/common/icon-person.svg) no-repeat center center;
	transition: 0.6s;
	
  }
  
  .menu .icon.cart a:before {
	content:"";
	position: absolute;
	width: 24px;
	height: 24px;
	top:20px;
	left: 20px;
	display: block;
	background:url(/html/template/sodastream/assets/img/common/icon-cart.svg) no-repeat center center;
	transition: 0.6s;
  }
  
  .menu .icon.login a:hover:before,
  .menu .icon.cart a:hover:before{
	opacity: 0.7;
  }
  
  
  .menu .menu_list01 > a,
  .menu .menu_list02 > a,
  .menu .menu_list03 > a{
	border-left: 1px solid #eeeeee;
	border-right: 1px solid #eeeeee;
	padding: 0px 60px 0 26px;
  }
  
 
  
  .menu .menu_list01 > a:after,
  .menu .menu_list02 > a:after,
  .menu .menu_list03 > a:after{
	position: absolute;
	right: 30px;
	display: block;
	top:27px;
	content: '';
	width: 16px;
	height: 16px;
	transition: transform .4s;
	background: url(/html/template/sodastream/assets/img/common/icon-arrow-black.svg) no-repeat center center;
  }
  
  .menu .menu_list01 > a.hover,
  .menu .menu_list02 > a.hover,
  .menu .menu_list03 > a.hover {
	color: #fff;
	background: #7fbff5;
	
  }
  
  .menu .menu_list01 > a.hover:after,
  .menu .menu_list02 > a.hover:after,
  .menu .menu_list03 > a.hover:after{
	position: absolute;
  right: 30px;
	display: block;
	top:27px;
	content: '';
	width: 16px;
	height: 16px;
	transition: transform .4s;
	background: url(/html/template/sodastream/assets/img/common/icon-arrow-white.svg) no-repeat center center;
	transform: rotate(180deg);
  }
  
  .menu .menu_list > a:hover,
  .menu .menu_list01 > a:hover,
  .menu .menu_list02 > a:hover,
  .menu .menu_list03 > a:hover{
	background: #7fbff5;
	color: #fff;
  }
  
  .menu .single > a:hover{
	color: #7fbff5;
  }
  
  .menu_contents .boxArea, body, .ec-layoutRole {
    background: #faf8f8;
}
  .menu .menu_list > a.two{
	line-height: 1.4rem;
	padding: 24px 0 10px;
  }
  .menu li.hover > a{
	color: #fff;
	background: #7fbff5;
  }
  .menu_contents {
  position: absolute;
  top:100%;
  left: 0;
  width: 100%;
  opacity: 0;
  transition: 0.6s;
  margin-top: -410px;
  z-index: -1;
  height: 400px;
  color: #000;
  padding-top:10px;
  }
  
  .menu_contents .boxArea{
	border-radius: 35px;
	padding: 30px 0px 0;
	box-shadow: 0px 3px 20px #5253531a;
  }
  
  .menu_contents.showDown{
  opacity: 1;
  margin-top: 0;
  }
  
  .menu_contents ul{
	/*display: flex;*/
	text-align: center;
	padding-bottom: 20px;
  }
  .menu_contents li {
    position: relative;
    overflow: hidden;
    width: 170px;
    height: 170px;
    display: inline-block;
    border-radius: 30px;
    margin: 0 8px;
  }
  .menu_contents ul li.two{
	position: relative;
	overflow: hidden;
	width: 340px;
	height: 170px;
	display: inline-block;
  }

  
  .menu_contents li.border{
	border: 1px solid #dadddf;
  }
  
  .menu_contents ul li:after{
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	top: 0;
	background: url(/html/template/sodastream/assets/img/common/head_about_img01.png) no-repeat center center;
	background-size: cover;
	transition: all .3s ease-out;
  }
  .menu_list02 .menu_contents ul {
    display: flex;
    align-items: center;
    justify-content: center;
}
.menu_list02 .menu_contents ul li:nth-child(2),
.menu_list02 .menu_contents ul li:nth-child(3) {
    position: relative;
    overflow: hidden;
    width: 170px;
    height: 170px;
    display: inline-block;
}

.menu_list01 .menu_contents ul li:nth-child(1):after{
	background: url(/html/template/sodastream/assets/img/common/header-nav-about01.jpg) no-repeat top center;
  background-size: 100% auto;
  }
.menu_list01 .menu_contents ul li:nth-child(2):after{
	background: url(/html/template/sodastream/assets/img/common/header-nav-about02.jpg) no-repeat top center;
  background-size: 100% auto;
  }
.menu_list01 .menu_contents ul li:nth-child(3):after{
	background: url(/html/template/sodastream/assets/img/common/header-nav-about03.jpg) no-repeat top center;
  background-size: 100% auto;
  }
.menu_list01 .menu_contents ul li:nth-child(4):after{
	background: url(/html/template/sodastream/assets/img/common/header-nav-about04.jpg) no-repeat top center;
  background-size: 100% auto;
  }

 .menu_list02 .menu_contents ul li:nth-child(1):after{
	background: url(/html/template/sodastream/assets/img/common/header-nav-store01.jpg) no-repeat top center;
  background-size:cover;
  }
.menu_list02 .menu_contents ul li:nth-child(2):after{
		background: url(/html/template/sodastream/assets/img/common/header-nav-store02.jpg) no-repeat top center;
    background-size:cover;
	}
.menu_list02 .menu_contents ul li:nth-child(3):after{
		background: url(/html/template/sodastream/assets/img/common/header-nav-store03.jpg) no-repeat top center;
    background-size:cover;
	}
.menu_list02 .menu_contents ul li:nth-child(4):after{
		background: url(/html/template/sodastream/assets/img/common/header-nav-store04.jpg) no-repeat top center;
    background-size:cover;
	}
.menu_list02 .menu_contents ul li:nth-child(5):after{
		background: url(/html/template/sodastream/assets/img/common/header-nav-store05.jpg) no-repeat top right;
    background-size:cover;
	}

.menu_list03 .menu_contents ul li:nth-child(3):after{
	background: url(/html/template/sodastream/assets/img/common/header-nav-gas01.jpg) no-repeat top center;
  background-size: 100% auto;
}

.menu_list03 .menu_contents ul li:nth-child(1):after{
	background: url(/html/template/sodastream/assets/img/common/header-nav-gas02.jpg) no-repeat top center;
  background-size: 100% auto;
}

.menu_list03 .menu_contents ul li:nth-child(2):after{
	background: url(/html/template/sodastream/assets/img/common/header-nav-gas03.jpg) no-repeat top center;
  background-size: 100% auto;
}
  
  
.menu_contents ul li:hover:after{
  opacity: .8;
  transform: scale(1.1);
}
  
.menu_contents ul li a {
  position: relative;
  display: block;
  width: 100%;
  text-align: center;
  padding:14px 0 0;
  z-index: 1;
  height: 200px;
  text-decoration: none;
  color: #fff;
  font-weight: bold;
  font-size: 14px;
}

.menu_list02 .menu_contents ul li.two a,
.menu_list03 .menu_contents ul li.two a{
  text-align: left;
  font-size: 15px;
  padding: 28px 0 0 40px;
  letter-spacing: 0.05em;
  line-height: 1.8;
}

.menu_list02 .menu_contents ul li.two span.btn,
.menu_list03 .menu_contents ul li.two span.btn{
  background: #FEEF94;
  color: #002349;
  border-radius: 20px;
  padding: 6px 20px;
  letter-spacing: 0.05em;
  font-size: 13px;
  display: inline-block;
  margin-top: 20px;
}

.bold{
	font-weight: bold !important;
}

.eng{
	font-family: 'Poppins', sans-serif;
	letter-spacing: 0.05em;
}
  
.menu_contents .subInfo{
	border-top: 1px solid #eceeef;
	text-align: center;
}
  
  .menu_contents .subInfo{
	border-top: 1px solid #eceeef;
	text-align: center;
	padding: 20px 0 20px;
	color:#005D6E;
  }
  
  .menu_contents .subInfo p{
	display: inline-block;
	margin-right: 60px;
	font-size: 14px;
  }
  
  .menu_contents .subInfo a {
  position: relative;
  display: inline-block;
  text-decoration: none;
  margin-left: 20px;
  color: #002349;
  font-size: 14px;
  }
  .menu_contents .subInfo a::after {
  position: absolute;
  bottom: -4px;
  left: 0;
  content: '';
  width: 100%;
  height: 1px;
  background: #7fbff5;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform .3s;
  }
  .menu_contents .subInfo a:hover::after {
  transform: scale(1, 1);
  }
  
  .menu_contents .subInfo a::before{
	position: absolute;
	width: 16px;
	height: 16px;
	top: 2px !important;
	right:-26px;
	content: '';
	background: url(/html/template/sodastream/assets/img/common/icon-arrow-black-right.svg) no-repeat center center;
	fill: #7fbff5 !important;
	transition: all .3s ease-out;
	top:0px;
  }
  
.menu_contents .subInfo a:hover::before{
  right:-32px;
}
  
a.black{
    color:#002238 !important;
}

#mainvisualArea{
    padding-top: 50px !important;
}
.menu .simpleBtn {
    margin: -10px 0 20px;
}
.menu .simpleBtn a {
    background: #002238;
    color: #fff;
    width: 216px;
    height: 60px;
    text-align: center;
    margin: 0 auto;
    display: block;
    border-radius: 93px;
    line-height: 60px;
    font-size: 13px;
    text-decoration: none;
    transition: .5s;
}
.menu .simpleBtn a:hover {
    background: #7fbff5;
    border-radius: 93px;
}
.catalog{
    position: relative;
}
.catalog a img{
    position: absolute;
    top: 74%;
    left: 11%;
}
#main-content .flex {
    display: flex;
    justify-content: space-between;
    padding: 40px 40px;
    width: 100%;
}
#main-content .flex .flexBox {
    display: inline-flex;
    flex-basis: 46%;
    margin: 20px;
}
#main-content .plastic {
    max-width: 1040px;
    margin: 0 auto 20px;
}
#main-content .about {
    max-width: 700px;
    margin: 0 auto 20px;
}

}


.u-sp{ display:none; }
.u-pc{ display:block; }
@media (max-width: 768px){
  .u-sp{ display:block; }
  .u-pc{ display:none; }
   .u-spFull {
    width: 100%;
  }
}

@media only screen and (min-width: 768px) {
    .ec-footerRole {
        margin-top: 0px;
    }
}

/******************************************************　SP　ナビ***********************************************************************/

.c-header__pc { display: block; }
.c-header__sp { display: none; }

@media (max-width: 768px){
  .c-header__pc { display: none; }
  .c-header__sp {
    display: grid;
        grid-template-columns: 0.3fr 1.5fr 1fr;
  }
  .pc_disp{
    display: none;
    
    }
    .sp_disp{
        display: block;
    }
}



@media screen and (max-width: 768px){

:root{
      --panel: rgba(20,20,22,.92);
      --panel2: rgba(14,14,16,.96);
      --text: #f6f6f7;
      --muted: rgba(246,246,247,.72);
      --line: rgba(246,246,247,.12);
      --shadow: 0 20px 70px rgba(0,0,0,.55);
      --r: 18px;
      --ease: cubic-bezier(.2,.85,.2,1);
      --dur: 320ms;
      --headerH: 64px;
      --panelW: min(90vw, 440px);
      --topOffset: 0px;
  }

body{
  padding-top: var(--headerH);
}

body.notice{
  --topOffset: 50px; /* 注意書きが出たときだけ上書き */
}


    *{ box-sizing:border-box; }
    body{
      margin:0;
      min-height:100vh;
    }

    /* ===== Header (always usable) ===== */
    .c-header__sp{
      position: fixed;
      top: var(--topOffset);
      z-index: 100;
      height: var(--headerH);
      align-items:center;
      gap: 12px;
      padding: 0px;
      width: 100%;
      background: #FAF8F8;
      box-shadow: 0 3px 20px #52535326;
    }

    .c-header__hamburger{
      appearance:none;
      border: 1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.06);
      color: var(--text);
      border-radius: 999px;
      height: 42px;
      width: 52px;
      display:grid;
      place-items:center;
      cursor:pointer;
      transition: transform var(--dur) var(--ease);
    }
    .c-header__hamburger:active{ transform: scale(.98); }



/* ===== Hamburger → X (final correct version) ===== */
.c-header__hamburgerIcon{
  width: 26px;
  height: 16px;
  position: relative;
}

.c-header__hamburgerIcon span{
  position:absolute;
  left: 0;                     /* ← 通常は左寄せ */
  height: 2px;
  border-radius: 99px;
  background:#002349;
  transform-origin: center center;
  transition:
    transform var(--dur) var(--ease),
    opacity var(--dur) var(--ease),
    width var(--dur) var(--ease),
    left var(--dur) var(--ease),
    top var(--dur) var(--ease);
}

/* 閉じている時（左寄せ・長さ違い） */
.c-header__hamburgerIcon span:nth-child(1){ top: 0;  width: 26px; }
.c-header__hamburgerIcon span:nth-child(2){ top: 7px; width: 20px; }
.c-header__hamburgerIcon span:nth-child(3){ top: 14px; width: 14px; }

/* 開いた時：中央で×になる */
body.navOpen .c-header__hamburgerIcon span:nth-child(1){
  left: 50%;
  top: 7px;
  width: 26px;
  transform: translateX(-50%) rotate(45deg);
}

body.navOpen .c-header__hamburgerIcon span:nth-child(2){
  opacity: 0;
}

body.navOpen .c-header__hamburgerIcon span:nth-child(3){
  left: 50%;
  top: 7px;
  width: 26px;
  transform: translateX(-50%) rotate(-45deg);
}


.c-header__brand{
  display:flex; align-items:center; gap:10px;
  text-decoration:none; color: var(--text);
  font-weight: 700;
  letter-spacing: .02em;
  margin-left: auto;
}

.c-header__brandMark{
  width: 26px; height: 26px; border-radius: 9px;
  background: linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
}

.c-header__nav{
  position: relative;
  display: flex;
  padding-left:10px;
  justify-content: flex-start;
  align-items: center;
}


.c-header__nav li:nth-child(2) a,
.c-header__nav li:nth-child(3) a{
  display: block;
	height: 60px;
	line-height: 60px;
	overflow: hidden;
	position: relative;
	width: 40px;
  text-align: center;
	text-indent: 100%;
  position: relative;
}

.c-header__nav a span{
  display: none;
}

.c-header__nav .icon.login a:before {
	content:"";
	position: absolute;
	width: 21px;
	height: 24px;
	top:20px;
	left: 14px;
	display: block;
	background:url(/html/template/sodastream/assets/img/common/icon-person.svg) no-repeat center center;
  background-size: 100% auto;
	transition: 0.6s;
}
  
.c-header__nav .icon.cart a:before {
	content:"";
	position: absolute;
	width: 22px;
	height: 24px;
	top:19px;
	left: 10px;
	display: block;
	background:url(/html/template/sodastream/assets/img/common/icon-cart.svg) no-repeat center center;
  background-size: 100% auto;
	transition: 0.6s;
}
  


    .hero{
      max-width: 980px;
      margin: 18px auto 0;
      padding: 22px;
      border-radius: 22px;
      background: rgba(255,255,255,.05);
      border: 1px solid rgba(255,255,255,.10);
      box-shadow: 0 16px 50px rgba(0,0,0,.4);
    }
    .hero h1{ margin:0 0 10px; font-size: 22px; }
    .hero p{ margin:0; color: var(--muted); line-height: 1.7; }

    /* ===== Overlay (starts BELOW header) ===== */
    .navOverlay{
      position: fixed;
      left: 0;
      right: 0;
      bottom: 0;
      top: var(--headerH);     /* ← ヘッダー下から開始 */
      z-index: 50;
      pointer-events: none;
    }

    .navOverlay__dim{
      position:absolute;
      inset:0;
      background: rgba(0,0,0,.45);
      opacity: 0;
      transition: opacity var(--dur) var(--ease);
    }

    .navPanel{
      position:absolute;
      top: calc(var(--topOffset) + 0px);
      bottom: 10px;
      bottom:0px;
      left:0px;
      width: var(--panelW);
      background:#faf8f8;
      box-shadow: var(--shadow);
      backdrop-filter: blur(14px);
      overflow: hidden;
      transform: translateX(-10px) scale(.985);
      opacity: 0;
      transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
      pointer-events: none;
      color: #002349;
    }

    body.navOpen .navOverlay{ pointer-events: auto; }
    body.navOpen .navOverlay__dim{ opacity: 1; }
    body.navOpen .navPanel{
      pointer-events: auto;
      transform: translateX(0) scale(1);
      opacity: 1;
    }

    .navPanel__top{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:10px;
      padding: 14px 14px 12px;
      border-bottom: 1px solid var(--line);
    }
    .navTitle{
      font-weight: 700;
      letter-spacing: .02em;
      display:flex; align-items:center; gap:10px;
    }
    .pill{
      font-size: 12px;
      color: rgba(255,255,255,.75);
      border: 1px solid rgba(255,255,255,.14);
      padding: 4px 10px;
      border-radius: 999px;
      background: rgba(255,255,255,.06);
    }
    .closeBtn{
      appearance:none;
      border: 1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.06);
      color: var(--text);
      border-radius: 999px;
      height: 38px;
      padding: 0 12px;
      cursor:pointer;
    }

    .navStage{
      height: calc(100% - 10px);
      position: relative;
      overflow: hidden;
    }
    .navTrack{
      height: 100%;
      width: 200%;
      display:flex;
      transform: translateX(0%);
      transition: transform var(--dur) var(--ease);
    }
    .navTrack.isSub{ transform: translateX(-50%); }

    .navView{
      width: 50%;
      height: 100%;
      overflow: auto;
      -webkit-overflow-scrolling: touch;
      padding:0px 14px 0;
    }

    .navGrid{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap: 12px 32px;
      padding: 20px 40px 20px;
    }
    .navList{
      margin-top: 20px;
    }
    .navList ul li a{
      display: block;
      border-top:1px solid #D5D9DB;
      font-size: 16px;
      letter-spacing: 0.05em;
      padding: 16px 20px;
      color: #002349;
      font-weight: bold;
    }

    .navCard{
      align-items: center;
      text-decoration:none;
      color:#002349;
      border-radius: var(--r);
      border: 1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.05);
    }
    .navThumb{
      width: 100%;
      aspect-ratio: 1 / 1;
      border-radius: 14px;
      overflow:hidden;
      border: 1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.06);
    }
    .navThumb02{
      width: 100%;
      aspect-ratio: 2 / 1;
      border-radius: 14px;
      overflow:hidden;
      border: 1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.06);
    }
    .navThumb02 img{ width: 100%; display:block; height:auto; }

    .navThumb img{
      width:100%; height:100%;
      object-fit: cover;
      display:block;
    }
    .navMeta{
      min-width: 0;
      display:flex;
      flex-direction: column;
      gap: 4px;
    }
    .navMeta__title{ font-weight: 700; font-size: 15px; line-height: 1.25; }
    .navMeta__desc{ 
      font-size: 12px;
      color: #002349;
      line-height: 1.5;
    }
    .navChevron{ 
      color: #002349;
      font-size: 18px;
      justify-self: end;
    }

    .navSub{ 
      background: #faf8f8;
    }

    .subHeader{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap: 10px;
      padding-bottom: 12px;
      margin-bottom: 12px;
      border-bottom: 1px solid var(--line);
      position: sticky;
      top: 0;
      background:#faf8f8;
      border-radius: 16px;
      padding: 10px;
      z-index: 2;
    }

    .backBtn{
      appearance:none;
      border: 1px solid rgba(255,255,255,.14);
      color: #002349;
      border-radius: 999px;
      height: 38px;
      padding: 0px;
      cursor:pointer;
      font-size: 18px;
      background: none;
      letter-spacing:0.1em;
      font-weight: bold;
    }
    .backBtn span{
      font-size: 26px;
      padding-right: 10px;
    }
    .subTitle{ font-weight: 700; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; opacity: 0 !important;}
    .subCTA{
      font-size: 12px;
      color:#002349;
      border: 1px solid rgba(255,255,255,.14);
      padding: 6px 10px;
      border-radius: 999px;
      text-decoration:none;
      flex: 0 0 auto;
    }

    .subMenus{ 
      display:grid;
      grid-template-columns: 1fr;
      padding: 0 16px;
    }
    .subMenu{ 
      display:none;
    }
    .subMenu.isActive{
      display: block;
    }
    .subMenu__list{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 20px;
      margin-bottom: 20px;
    }

    .subMenu__list{
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
    }

    /* これが超重要：gridアイテムが親を押し広げるのを防ぐ */
    .subMenu__list > *{ min-width: 0; }

    .subLink--wide{
      grid-column: 1 / -1;  /* 全列スパン */
    }

    /* 画像が押し広げないように */
    .navThumb img{
      display: block;
      width: 100%;
      height: auto;
    }

    .subLink{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap: 12px;
      border-radius: 16px;
      text-decoration:none;
      color:#002349;
      border: 1px solid rgba(255,255,255,.12);
    }

    .subNavBack a {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      color:#002349;
      font-size: 18px;
      font-weight: bold;
    }
    .subNavBack img {
      width: 22px;
      height: auto;
    }


    .subLink small{ color: var(--muted); display:block; margin-top: 2px; }
    .subLink span{ font-weight: 650; }

  }



    @media (prefers-reduced-motion: reduce){
      *{ transition: none !important; scroll-behavior: auto !important; }
    }


.u-visuallyHidden{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}



/* footer */

.ec-layoutRole .ec-layoutRole__footer .ec-footerRole, .ec-footerRole {
    background: #00244D;
}

  .ec-footerRole .ec-footerRole__inner{
	display: flex;
	justify-content: space-between;
	width: 100%;
  margin: 0 auto;
  }

  .ec-footerRole .ec-footerRole__inner {
    max-width: 1200px;
    padding: 70px 30px;
}
  
.ec-footerRole .ec-footerRole__inner #footerInfo p#copyright {
    font-family: 'Poppins', sans-serif;
    color: #fff;
    font-size: 12px;
    margin: 20px 0 50px;
    letter-spacing: 0.05em;
    font-weight: 300;
}

  .ec-footerRole .ec-footerRole__inner #footerInfo{
	display: inline-flex;
	flex-direction: column;
  }
  
  .ec-footerRole .ec-footerRole__inner #footerLink{
	display: inline-flex;
  }
  
  .ec-footerRole .ec-footerRole__inner #footerLink .box p.ttl{
	font-family: 'Poppins', sans-serif;
	color: #EFEBE4;
	font-size: 22px;
	margin: 0px 0 30px;
	letter-spacing: 0.05em;
	font-weight: 700;
	padding: 10px 0;
  }
  
  .ec-footerRole .ec-footerRole__inner #footerLink .box{
	margin-left: 50px;
  }
  .ec-footerRole .ec-footerRole__inner #footerLink .box ul {
	min-width: 180px;
  }
  
  .ec-footerRole .ec-footerRole__inner #footerLink .box.wide{
	min-width: 188px;
  }
  
  .ec-footerRole .ec-footerRole__inner #footerLink .box ul li a{
	color:#EFEBE4;
	font-size: 13px;
	margin-bottom: 10px;
	display: inline-block;
  }
  .ec-footerRole .ec-footerRole__inner #footerLink .box ul li a:hover{
	color:#EFEBE4;
  }
  
  .ec-footerRole .ec-footerRole__inner:after{
	display: none;
  }
  .ec-layoutRole .ec-layoutRole__footer .ec-footerRole__bar,
  .ec-footerRole__bar{
	background:#005d6e;
  }

  .ec-blockTopBtn{
    display: none;
    position: fixed;
    width:120px;
    height: 40px;
    right: 0;
    bottom: 10px;
    cursor: pointer;
    color: #FFFFFF;
    text-align: center;
    line-height: 40px;
    opacity: 0.8;
    background-color: #9da3a9;
  }


    .ec-footerRole .ec-footerRole__inner #footerInfo ul#sns li{
	display: inline-block;
	margin-right: 10px;
  }
  
  .ec-footerRole .ec-footerRole__inner #footerInfo ul#sns li.twitter a{
	background: url(/html/template/sodastream/assets/img/common/icon-twitter-blue.svg) no-repeat;
	width: 38px;
	height: 38px;
	display:block;
  }
  .ec-footerRole .ec-footerRole__inner #footerInfo ul#sns li.facebook a{
	background: url(/html/template/sodastream/assets/img/common/icon-facebook-blue.svg) no-repeat;
	width: 38px;
	height: 38px;
	display:block;
  }
  .ec-footerRole .ec-footerRole__inner #footerInfo ul#sns li.instagram a{
	background: url(/html/template/sodastream/assets/img/common/icon-insta-blue.svg) no-repeat;
	width: 38px;
	height: 38px;
	display:block;
  }
  .ec-footerRole .ec-footerRole__inner #footerInfo ul#sns li.youtube a{
	background: url(/html/template/sodastream/assets/img/common/icon-youtube-blue.svg) no-repeat;
	width: 38px;
	height: 38px;
	display:block;
  }
  
  .ec-footerRole .ec-footerRole__inner #footerInfo ul#sns li.twitter a:hover{
	background: url(/html/template/sodastream/assets/img/common/icon-twitter-blue-hover.svg) no-repeat;
  }
  .ec-footerRole .ec-footerRole__inner #footerInfo ul#sns li.facebook a:hover{
	background: url(/html/template/sodastream/assets/img/common/icon-facebook-blue-hover.svg) no-repeat;
  }
  .ec-footerRole .ec-footerRole__inner #footerInfo ul#sns li.instagram a:hover{
	background: url(/html/template/sodastream/assets/img/common/icon-insta-blue-hover.svg) no-repeat;
  }
  .ec-footerRole .ec-footerRole__inner #footerInfo ul#sns li.youtube a:hover{
	background: url(/html/template/sodastream/assets/img/common/icon-youtube-blue-hover.svg) no-repeat;
  }





@media screen and (max-width: 768px){

  .ec-footerRole .ec-footerRole__inner{
    display:block;
    width: 100%;
  }
  .ec-footerRole .ec-footerRole__inner #footerInfo{
    display:block;
    width: 100%;
  }
  .ec-footerRole .ec-footerRole__inner {
      padding: 50px 15px;
  }
  .ec-footerRole .ec-footerRole__inner #logo {
      width: 222px;
  }
  .ec-footerRole .ec-footerRole__inner #footerInfo p#copyright {
      font-family: 'Poppins', sans-serif;
      color: #EFEBE4;
      font-size: 12px;
      margin: 20px 0 50px;
      letter-spacing: 0.05em;
      font-weight: 300;
  }

  .ec-footerRole .ec-footerRole__inner #footerLink {
      margin-top: 50px;
      display: block;
      width: 100%;
  }
  .ec-footerRole .ec-footerRole__inner #footerLink .box {
      margin-left: 0px;
  }
  .ec-footerRole .ec-footerRole__inner #footerLink .box.wide {
      min-width: 188px;
  }
  .ec-footerRole .ec-footerRole__inner #footerLink .box {
      margin-left: 0px;
  }

  .ec-overlayRole {
      position: fixed;
      width: 100%;
      height: 100vh;
      top: 0;
      left: 0;
      opacity: 0;
      background: transparent;
      transform: translateX(0);
      transition: all .3s;
      visibility: hidden;
      z-index: 100;
  }


  .ec-footerRole .ec-footerRole__inner #footerLink .box p.ttl {
      position: relative;
      font-size: 16px;
      border-bottom: 1px solid rgba(213, 213, 213, 0.3);
      font-family: 'Poppins', sans-serif;
      color: #EFEBE4;
      margin: 0px 0 30px;
      letter-spacing: 0.05em;
      font-weight: 700;
      padding: 10px 0;
  }

  .ec-footerRole .ec-footerRole__inner #footerLink .box p.ttl:after {
      display: block;
      content: "";
      width: 16px;
      height: 16px;
      background: url(/html/template/sodastream/assets/img/common/icon-arrow-sand.svg) no-repeat;
      transform: scale(1, 1);
      position: absolute;
      top: 4px;
      right: 10px;
  }

  .ec-footerRole .ec-footerRole__inner #footerLink .box ul li a {
      color: #EFEBE4;
      font-size: 13px;
      margin-bottom: 10px;
      display: inline-block;
  }

  .ec-drawerRoleClose.is_active {
      display: inline-block;
      transition: all .3s;
  }

  .ec-drawerRoleClose {
      display: none;
      cursor: pointer;
      box-sizing: border-box;
      padding: 0;
      width: auto;
      height: 50px;
      font-size: 18px;
      text-align: center;
      color: black;
      border-right: 1px solid #CCC;
  }
  .ec-drawerRole__header {
      display: table;
      width: 100%;
      border-bottom: 1px solid #CCC;
  }
  .ec-drawerRole__header__logo {
      text-align: right;
      display: table-cell;
  }
  .ec-drawerRole__header__logo img {
      width: 136px;
      height: auto;
      padding-right: 20px;
  }
  .ec-drawerRole.is_active {
      display: table-cell;
      transform: translateX(0);
      transition: all .3s;
      z-index: 100000;
      background: transparent;
  }

  .have_curtain .ec-overlayRole {
      display: block;
      opacity: 1;
      background: rgba(0, 0, 0, 0.5);
      visibility: visible;
  }
  .ec-drawerRole .ec-drawerRole__inner {
      overflow: auto;
      margin-right: 10px;
      height: 100%;
      box-shadow: 2px 0px 2px rgba(0, 0, 0, 0.2);
  }

  .ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav li ul li a {
      background: #e5e1dc;
  }
  .ec-blockTopBtn {
      display: none;
      position: fixed;
      width: 120px;
      height: 40px;
      right: 0;
      bottom: 10px;
      cursor: pointer;
      color: #FFFFFF;
      text-align: center;
      line-height: 40px;
      opacity: 0.8;
      background-color: #9da3a9;
  }
}



.section{
  padding-block: var(--space-section);
  scroll-margin-top: 60px;
}