@charset "utf-8";

/*-------------------------------------------------------------------------------------------------------------------------------
* reset
-------------------------------------------------------------------------------------------------------------------------------*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
main, article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video{
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	box-sizing: border-box;
}
body {
	line-height: 1;
}
img{
	max-width: 100%;
	vertical-align: bottom;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}

/*-------------------------------------------------------------------------------------------------------------------------------
* 基本設定
-------------------------------------------------------------------------------------------------------------------------------*/
:root {
	--primary-color: #1a3167;
	--secondary-color: #4e97b7;
	--bg-color: #e8eef2;
}

html {
	font-size: 10px;
	font-family: "Noto Sans JP", sans-serif;
	font-feature-settings: "palt";
}
@media (max-width: 767px) {
	html {
		font-size: 1.33vw;
	}
}
body{
	font-size: 12px;
	color: #2e2624;
	line-height: 1.3;
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	-webkit-text-size-adjust:100%;
}
@media screen and (max-width:767px) {
	body{
		font-size: 1.2rem;
	}
}

.primary-color {
	color: var(--primary-color);
}

.secondary-color {
	color: var(--secondary-color);
}

.visually-hidden {
  position: absolute;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  width: 1px;
  height: 1px;
  white-space: nowrap;
}

/*-------------------------------------------------------------------------------------------------------------------------------
* index
-------------------------------------------------------------------------------------------------------------------------------*/
#container{
	width: 100%;
	margin: 0 auto;
}

/*-------------------------------------------------------------------------------------------------------------------------------
* main
-------------------------------------------------------------------------------------------------------------------------------*/
main{
	width: 750px;
  margin-inline: auto;
  line-height: 1.333;
}

/*-------------------------------------------------------------------------------------------------------------------------------
 pagetop
-------------------------------------------------------------------------------------------------------------------------------*/
#pagetop {
	display: none;
	position: fixed;
	z-index: 7000;
	right: 20px;
	bottom: 20px;
}

/*-------------------------------------------------------------------------------------------------------------------------------
* general.css
-------------------------------------------------------------------------------------------------------------------------------*/

/* inline block
====================================================================================== */
.dI {display:inline !important;}
.dB {display:block !important;}
.dIB {display:inline-block !important;}
.dN {display:none !important;}
.vN {visibility:hidden !important;}

/* position
====================================================================================== */
.relative {position: relative;}
.absolute {position: absolute;}

/* float
====================================================================================== */
.fltR {float:right !important;}
.fltL {float:left !important;}
.clip {overflow:hidden !important;}
.clear {clear:both !important;}


/* text-align
====================================================================================== */
.taR{text-align:right !important;}
.taL{text-align:left !important;}
.taC{text-align:center !important;}


/* width
====================================================================================== */
.wA {width:auto !important;}
.w20 {width:20% !important;}
.w25 {width:25% !important;}
.w50 {width:50% !important;}
.w75 {width:75% !important;}
.w100 {width:100% !important;}
.w-fit {width: fit-content;}


/* margin
====================================================================================== */
.m00 {margin: 0   !important;}
.m05 {margin: 5px !important;}
.m10 {margin:10px !important;}
.m12 {margin:12px !important;}
.m15 {margin:15px !important;}
.m20 {margin:20px !important;}
.m25 {margin:25px !important;}
.m30 {margin:30px !important;}
.m35 {margin:35px !important;}
.m40 {margin:40px !important;}
.m45 {margin:45px !important;}
.m50 {margin:50px !important;}
.mt00 {margin-top: 0   !important;}
.mt05 {margin-top: 5px !important;}
.mt10 {margin-top:10px !important;}
.mt12 {margin-top:12px !important;}
.mt15 {margin-top:15px !important;}
.mt20 {margin-top:20px !important;}
.mt25 {margin-top:25px !important;}
.mt30 {margin-top:30px !important;}
.mt35 {margin-top:35px !important;}
.mt40 {margin-top:40px !important;}
.mt45 {margin-top:45px !important;}
.mt50 {margin-top:50px !important;}
.mt80 {margin-top:80px !important;}
.mr00 {margin-right: 0   !important;}
.mr05 {margin-right: 5px !important;}
.mr10 {margin-right:10px !important;}
.mr12 {margin-right:12px !important;}
.mr15 {margin-right:15px !important;}
.mr20 {margin-right:20px !important;}
.mr25 {margin-right:25px !important;}
.mr30 {margin-right:30px !important;}
.mr35 {margin-right:35px !important;}
.mr40 {margin-right:40px !important;}
.mr45 {margin-right:45px !important;}
.mr50 {margin-right:50px !important;}
.mb00 {margin-bottom: 0   !important;}
.mb03 {margin-bottom: 3px !important;}
.mb05 {margin-bottom: 5px !important;}
.mb10 {margin-bottom:10px !important;}
.mb12 {margin-bottom:12px !important;}
.mb15 {margin-bottom:15px !important;}
.mb20 {margin-bottom:20px !important;}
.mb25 {margin-bottom:25px !important;}
.mb30 {margin-bottom:30px !important;}
.mb35 {margin-bottom:35px !important;}
.mb40 {margin-bottom:40px !important;}
.mb45 {margin-bottom:45px !important;}
.mb50 {margin-bottom:50px !important;}
.mb55 {margin-bottom:55px !important;}
.mb75 {margin-bottom:75px !important;}
.mb100 {margin-bottom:100px !important;}
.ml00 {margin-left: 0   !important;}
.ml05 {margin-left: 5px !important;}
.ml10 {margin-left:10px !important;}
.ml12 {margin-left:12px !important;}
.ml15 {margin-left:15px !important;}
.ml20 {margin-left:20px !important;}
.ml25 {margin-left:25px !important;}
.ml30 {margin-left:30px !important;}
.ml35 {margin-left:35px !important;}
.ml40 {margin-left:40px !important;}
.ml45 {margin-left:45px !important;}
.ml50 {margin-left:50px !important;}
.m0A {margin:0 auto !important;}
.mx-auto{margin-inline: auto;}


/* padding
====================================================================================== */
.p00 {padding: 0   !important;}
.p05 {padding: 5px !important;}
.p10 {padding:10px !important;}
.p12 {padding:12px !important;}
.p15 {padding:15px !important;}
.p20 {padding:20px !important;}
.p25 {padding:25px !important;}
.p30 {padding:30px !important;}
.p35 {padding:35px !important;}
.p40 {padding:40px !important;}
.p45 {padding:45px !important;}
.p50 {padding:50px !important;}
.pt00 {padding-top: 0   !important;}
.pt05 {padding-top: 5px !important;}
.pt10 {padding-top:10px !important;}
.pt12 {padding-top:12px !important;}
.pt15 {padding-top:15px !important;}
.pt20 {padding-top:20px !important;}
.pt25 {padding-top:25px !important;}
.pt30 {padding-top:30px !important;}
.pt35 {padding-top:35px !important;}
.pt40 {padding-top:40px !important;}
.pt45 {padding-top:45px !important;}
.pt50 {padding-top:50px !important;}
.pt60 {padding-top:60px !important;}
.pt70 {padding-top:70px !important;}
.pt80 {padding-top:80px !important;}
.pt90 {padding-top:90px !important;}
.pt100 {padding-top:100px !important;}
.pr00 {padding-right: 0   !important;}
.pr05 {padding-right: 5px !important;}
.pr10 {padding-right:10px !important;}
.pr12 {padding-right:12px !important;}
.pr15 {padding-right:15px !important;}
.pr20 {padding-right:20px !important;}
.pr25 {padding-right:25px !important;}
.pr30 {padding-right:30px !important;}
.pr35 {padding-right:35px !important;}
.pr40 {padding-right:40px !important;}
.pr45 {padding-right:45px !important;}
.pr50 {padding-right:50px !important;}
.pb00 {padding-bottom: 0   !important;}
.pb05 {padding-bottom: 5px !important;}
.pb10 {padding-bottom:10px !important;}
.pb12 {padding-bottom:12px !important;}
.pb15 {padding-bottom:15px !important;}
.pb20 {padding-bottom:20px !important;}
.pb25 {padding-bottom:25px !important;}
.pb30 {padding-bottom:30px !important;}
.pb35 {padding-bottom:35px !important;}
.pb40 {padding-bottom:40px !important;}
.pb45 {padding-bottom:45px !important;}
.pb50 {padding-bottom:50px !important;}
.pb55 {padding-bottom:55px !important;}
.pb60 {padding-bottom:60px !important;}
.pb90 {padding-bottom:90px !important;}
.pb100 {padding-bottom:100px !important;}
.pb110 {padding-bottom:110px !important;}
.pl00 {padding-left: 0   !important;}
.pl05 {padding-left: 5px !important;}
.pl10 {padding-left:10px !important;}
.pl12 {padding-left:12px !important;}
.pl15 {padding-left:15px !important;}
.pl20 {padding-left:20px !important;}
.pl25 {padding-left:25px !important;}
.pl30 {padding-left:30px !important;}
.pl35 {padding-left:35px !important;}
.pl40 {padding-left:40px !important;}
.pl45 {padding-left:45px !important;}
.pl50 {padding-left:50px !important;}


/* boder
====================================================================================== */
.bdN{border:none !important;}
.bdtN{border-top:none !important;}
.bdbN{border-bottom:none !important;}


/* background
====================================================================================== */
.bgcT{background-color:transparent !important;}


/* font
====================================================================================== */
.fwN{font-weight:normal !important;}
.fwB{font-weight:bold !important;}

/* FONTサイズ (%) */
.fz80 { font-size:80% !important; }
.fz85 { font-size:85% !important; }
.fz90 { font-size:90% !important; }
.fz100 { font-size:100% !important; }
.fz110 { font-size:110% !important; }
.fz120 { font-size:120% !important; }
.fz130 { font-size:130% !important; }
.fz140 { font-size:140% !important; }
.fz150 { font-size:150% !important; }

/* FONTサイズ (固定) */
.fz10 { font-size:10px !important; }
.fz11 { font-size:11px !important; }
.fz12 { font-size:12px !important; }
.fz13 { font-size:13px !important; }
.fz14 { font-size:14px !important; }
.fz15 { font-size:15px !important; }
.fz16 { font-size:16px !important; }
.fz17 { font-size:17px !important; }
.fz18 { font-size:18px !important; }
.fz19 { font-size:19px !important; }
.fz20 { font-size:20px !important; }
.fz21 { font-size:21px !important; }
.fz22 { font-size:22px !important; }
.fz23 { font-size:23px !important; }
.fz24 { font-size:24px !important; }
.fz26 { font-size:26px !important; }
.fz28 { font-size:28px !important; }
.fz29 { font-size:29px !important; }
.fz30 { font-size:30px !important; }

/* line-height */
.lh11{ line-height:1.1 !important; }
.lh12{ line-height:1.2 !important; }
.lh13{ line-height:1.3 !important; }
.lh14{ line-height:1.4 !important; }
.lh15{ line-height:1.5 !important; }
.lh16{ line-height:1.6 !important; }
.lh17{ line-height:1.7 !important; }
.lh18{ line-height:1.8 !important; }
.lh19{ line-height:1.9 !important; }
.lh20{ line-height:2.0 !important; }

/* letter-spacing */
.ls002 {letter-spacing: 0.02em;}
.ls004 {letter-spacing: 0.04em;}
.ls006 {letter-spacing: 0.06em;}
.ls008 {letter-spacing: 0.08em;}
.ls01 {letter-spacing: 0.1em;}

/* ハンバーガーメニュー
====================================================================================== */
.hamburger-menu {
	position: sticky;
	top: 0;
	left: 0;
	z-index: 1;
}

.hamburger-menu button {
  background: none;
  border: none;
	padding-block: initial;
	padding-inline: initial;
}

.drawer-toggle-button {
	position: absolute;
	top: 36px;
	right: 20px;
	z-index: 2;
	cursor: pointer;
	width: 50px;
	height: auto;
	aspect-ratio: 1;
}

.drawer-line {
	position: relative;
	display: block;
	width: 100%;
	height: 3.5px;
	background-color: #00b4c3;
	border-radius: 100svw;
	background-color: opacity 0.2s;
}

.drawer-line::before,
.drawer-line::after {
	content: "";
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	background-color: #00b4c3;
	border-radius: 100svw;
	transition: rotate 0.2s;
}

.drawer-line::before {
	top: -16px;
}

.drawer-line::after {
	top: 16px;
}

.navlist-wrapper {
  position: fixed;
  top: 0;
  left: 50%;
	z-index: 1;
  translate: -50%;
	padding-block: 100px 40px;
  width: 750px;
	height: 100svh;
	background: url(/base/osaka/nihonshumatsuri/img/250806/common/bg01.svg) no-repeat center top / 696px 34px, var(--primary-color);
  transition: opacity 0.2s;
	opacity: 0;
	pointer-events: none;
	overflow-y: scroll;
}

.navlist-wrapper ul li:last-of-type {
	position: relative;
	left: -8px;
}

body.is-drawer-open {
  overflow: clip;
}

body.is-drawer-open .navlist-wrapper {
	opacity: 1;
	pointer-events: initial;
}

body.is-drawer-open .drawer-line {
	background-color: transparent;
}

body.is-drawer-open .drawer-toggle-button {
	right: 30px;
}

body.is-drawer-open .drawer-line::before,
body.is-drawer-open .drawer-line::after {
	top: 0;
	width: 120%;
}

body.is-drawer-open .drawer-line::before {
	rotate: 45deg;
}

body.is-drawer-open .drawer-line::after {
	rotate: -45deg;
}

/* 備考
====================================================================================== */
.remarks {
  margin-inline: 30px;
  padding: 42px 20px;
  background-color: #fff;
  color: var(--primary-color);
}