@charset "utf-8";
/*  ===========================================================
	株式会社彩プランニング --Irodori Planning Co.,Ltd--
		Last Update 2026/04/18	
			Written by Osamu Komatsu
===========================================================  */
/* =======================================
	HTML5 Browser Reset CSS
========================================== */
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, 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%;
	font-weight: normal;
	vertical-align: baseline;
    text-align: justify;
	background: transparent;
}
body {
	font-size: 16px;
	line-height: 1.5;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}
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;
}
hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #cccccc;
	margin: 1em 0;
	padding: 0;
}
input, select {
	vertical-align: middle;
}
a {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	outline: none;
}

/*!
 * Font Awesome Free 5.15.4 by @fontawesome - https://fontawesome.com
 * License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)
 */
@font-face {
  font-family: "Font Awesome 5 Free";
  font-style: normal;
  font-weight: 400;
  font-display: block;
  src: url(../font/fa-regular-400.eot);
  src: url(../font/fa-regular-400.eot?#iefix) format("embedded-opentype"), url(../font/fa-regular-400.woff2) format("woff2"), url(../font/fa-regular-400.woff) format("woff"), url(../font/fa-regular-400.ttf) format("truetype"), url(../font/fa-regular-400.svg#fontawesome) format("svg")
}
@font-face {
  font-family: "Font Awesome 5 Free";
  font-style: normal;
  font-weight: 900;
  font-display: block;
  src: url(../font/fa-solid-900.eot);
  src: url(../font/fa-solid-900.eot?#iefix) format("embedded-opentype"),
       url(../font/fa-solid-900.woff2) format("woff2"),
       url(../font/fa-solid-900.woff) format("woff"),
       url(../font/fa-solid-900.ttf) format("truetype"),
       url(../font/fa-solid-900.svg#fontawesome) format("svg")
}
/**/.fab, .far {
  font-weight: 400
}
.fa, .far, .fas {
  font-family: "Font Awesome 5 Free"
}
.fa, .fas {
  font-weight: 900
}
.fa-external-link-alt:before {
  content: "\f35d"
}

/*==================================
	common
==================================*/
* {
	box-sizing: border-box;
}
html {
	width: 100%;
	margin: 0 auto;
	font-size : 75%;
}
body {
  font-family: "Helvetica Neue",
    Arial, 
    "Hiragino Kaku Gothic ProN", 
    "Hiragino Sans", 
    Meiryo, 
    sans-serif;
	color: #333;
	background-color: #fff;
}

/* =======================================

	Calendar CSS

========================================== */

div#h_cal {
    text-align: center;
    background: #b30018;
    color: #fff;
    font-size: 1.5rem;
    padding: 0.3em;
    font-weight: bold;
}
.calendar_this{
	/*max-width: 100%;*/
	width: 100%;
	border: 6px solid #fff;
	margin: 0 auto 0.5em;
	background: #fff;
}
.calendar_this:last-child{
	margin-bottom: 0;
}
.calendar_this th{
	width: calc( 100% / 7 );
	text-align: center;
	border: 1px solid #333;
	border-bottom: 2px solid #333;
}
.calendar_this td{
	width: calc( 100% / 7 );
	text-align: center;
	border: 1px solid #333;
	color: #000;
}
.calendar_this th.youbi_0,
.calendar_this td.youbi_0{
	background-color: #fee;
	color: #a80000;
}
.calendar_this th.youbi_6,
.calendar_this td.youbi_6{
	background-color: #ddf;
	color: #00f;
}
.calendar_this th.youbi_2{
	background-color: #9f9;
}
.calendar_this td.youbi_2{
	background-color: #444;
	color: #ddd;
}
.calendar_this td.fes{
	background-color: #444;
	color: #ddd;
}
.calendar_this td.fes1{
	background-color: #fee;
	color: #a80000;
}
.calendar_this td.gray.fes{
	background-color: transparent;
	color: transparent;
}
.calendar_this td.gray.fes1{
	background-color: transparent;
	color: transparent;
}
.calendar_this td.gray{
	color: transparent;
}
.calendar_this td.today{
	font-weight: bold;
	background: #ff9;
}
.calendar_this td.bis{
	background-color: #fff;
	color: #000;
}
.calendar_this td.gray.bis{
	background-color: #fff;
	color: #999;
}
.calendar_this td.youbi_0.bis{
	background-color: #fdd;
	color: #f00;
}
.calendar_this td.youbi_2.bis{
	background-color: #fff;
	color: #000;
}
.calendar_this td.youbi_6.bis{
	background-color: #ddf;
	color: #00f;
}
.calendar_this td.youbi_0.gray{
	background-color: #fff;
	color: #fff;
}
.calendar_this td.youbi_2.gray{
	background-color: #fff;
	color: #fff;
}
.calendar_this td.youbi_6.gray{
	background-color: #fff;
	color: #fff;
}

.calendar_this td.fes.today,
.calendar_this td.youbi_2.today{
	background-color: #666;
	color: #999;
	font-weight: bold;
	color: #000;
}
span.holi_cal {
    background: #444;
    border: 1px solid #999;
    width: 2em;
    display: inline-block;
    line-height: 1.5;
    vertical-align: middle;
    height: 1.2em;
}
span.month_cal {
    font-size: 2.5rem;
	font-weight: bold;
    vertical-align: bottom;
    display: inline-block;
}
.calendar_this th.noborder {
	border: none;
}
.calendar_this th.h2em {
    height: 2em;
    vertical-align: bottom;
	line-height: 0.6;
}
span.year_cal {
    font-size: 1.5rem;
	letter-spacing: -0.06em;
}
span.month_en_cal {
    font-size: 1.5rem;
	letter-spacing: -0.06em;
}
th.noborder.desc_cal {
    height: 1.5em;
    padding-top: 0.4em;
	padding-bottom: 0.2em;
}
p._today_ho {
    text-align: center;
    background: #f00;
    color: #fff;
    margin-top: 0.5em;
    font-size: 1.5rem;
    padding: 0.5em;
}
p._today_no {
    text-align: center;
    background: #090;
    color: #fff;
    margin-top: 0.5em;
    font-size: 1.5rem;
	padding: 0.3em 0 0.2em;
}

#calendar_fr {
	flex-wrap: wrap;
    border: 8px #b30018 solid;
	border-top: none;
	background: #b30018;
}
/*==================================
	---common style---
==================================*/
.catch {
	color: #1a459d;
	font-weight: bold;
	font-size: 16px;
	font-size: 1rem;
	line-height: 1.6;
	padding: 10px;
	border: 1px solid #1a459d;
	margin: 20px;
}
.cf:before,
.cf:after {
	content: "";
	display: table;
	clear: both;
}
.bold {
	font-weight: bold;
}
.red {
	color: #f00;
}
.blue {
	color: #00f;
}
.green {
	color: #0f0;
}
.center {
	text-align: center;
}
.red_bold {
	font-weight: bold;
	color: #f00;
}
.blue_bold {
	font-weight: bold;
	color: #00f;
}
.white {
	color: #fff;
}
.white_bold {
	font-weight: bold;
	color: #fff;
}
.both {
	clear: both;
}
#hidden {
	display: none;
}
.left20 {
	margin-left: 20px;
}
.homepage_img {
	margin-right: auto;
	margin-left: auto;
	width: 500px;
}
.txt_l {
	text-align: left;
}
.text_l {
	text-align: left;
	font-weight: bold;
}
.text_r {
	text-align: right;
	font-weight: bold;
}
.txt_indent {
	text-indent: 1em;
}
.f70 {
	font-size: 70%;
}
.f75{
	font-size: 75%;
	}
.f88 {
	font-size: 88%;
}
.f125 {
	font-size: 125%;
}
.f188 {
	font-size: 188%;
}
.f30 {
	font-size: 30px;
}
.float_r {
	float: right;
}
.float_l {
	float: left;
}
.marker_ye {
    background:linear-gradient(transparent 60%, #ff6 60%);
	font-weight:bold; 
}
.marker_re {
    background:linear-gradient(transparent 75%, #ffadad 75%);
	font-weight:bold; 
}
.pl05em{
    padding-left: 0.5em;
}
.spblock{
    display:block;
    text-align: left;
    line-height: 1.5;
}
.d_blk{
    display: block !important;
}
a.d_inl{
    display: inline !important;
}
a.link {
	background-image: url(../images/bk_li_arrow.png);
	background-repeat: no-repeat;
	display: inline-block;
	padding-left: 18px;
	background-position: 0px 5px;
}
img.img_l10 {
	float: right;
	padding-left: 10px;
}
img.img_lb10 {
	float: right;
	padding-left: 10px;
	padding-bottom: 10px;
}
img.img_tb10 {
	margin-top: 10px;
	margin-bottom: 10px;
}
img.img_tb20 {
	margin-top: 20px;
	margin-bottom: 20px;
}
img.img_b30 {
	margin-bottom: 30px;
}
.m_t50 {
	margin-top: 50px;
}
.m_t20 {
	margin-top: 20px;
}
.m_b20 {
	margin-bottom: 20px;
}
.shadow {
	box-shadow: 3px 3px 3px #ccc;
}
.f_r {
	float: right;
}
.f_l{
	float: left;
}
.del{
	text-decoration: line-through;
}
