@font-face {
  font-family: 'Material Icons';
  font-style: normal;
  font-weight: 400;
  src: url(https://example.com/MaterialIcons-Regular.eot);
  /* For IE6-8 */
  src: local('Material Icons'),
    local('MaterialIcons-Regular'),
    url(https://example.com/MaterialIcons-Regular.woff2) format('woff2'),
    url(https://example.com/MaterialIcons-Regular.woff) format('woff'),
    url(https://example.com/MaterialIcons-Regular.ttf) format('truetype');
}

.material-icons {
  font-family: 'Material Icons';
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  /* Preferred icon size */
  line-height: 1;
  text-transform: none;
  letter-spacing: normal;
  word-wrap: normal;
  white-space: nowrap;
  direction: ltr;
  display: inline-flex;
  vertical-align: middle;

  /* Support for all WebKit browsers. */
  -webkit-font-smoothing: antialiased;
  /* Support for Safari and Chrome. */
  text-rendering: optimizeLegibility;

  /* Support for Firefox. */
  -moz-osx-font-smoothing: grayscale;

  /* Support for IE. */
  font-feature-settings: 'liga';
}

/* Rules for sizing the icon. */

.material-icons.md-36 {
  font-size: 36px;
}

.table > :not(caption) > * > * {
  vertical-align: middle;
}

/* フローティングメニュー */

.floating-nav {
  position: fixed;
  width: 50px;
  right: 0;
  top: 10%;
  cursor: pointer;
}

.floating-nav a {
  color: white;
  writing-mode: vertical-rl;
  text-orientation: upright;
  text-decoration: none;
}

/* TOTOPアイコン */
.totop {
  position: absolute;
  top: -60px;
  right: 40px;
}

/* 各種クラスボックス */

.box28 {
  position: relative;
  margin: 2em 0;
  padding: 25px 10px 7px;
  border: solid 2px #FFC107;
}
.box28 .box-title {
  position: absolute;
  display: inline-block;
  top: -2px;
  left: -2px;
  padding: 0 9px;
  height: 25px;
  line-height: 25px;
  font-size: 17px;
  background: #FFC107;
  color: #ffffff;
  font-weight: bold;
}
.box28 p {
  margin: 0; 
  padding: 0;
}


.box5 {
  padding: 0.5em 1em;
  margin: 2em 0;
  border: double 5px #DDFFDD;
}
.box5 p {
  margin: 0; 
  padding: 0;
}

.cp_hr01 {
	border-width: 1px 0 0 0;
	border-style: solid;
	border-color: #43a047;
}


/* ~~ お問い合わせ ~~ */
.reserve { width: 847px; margin: 35px auto 0 auto; }
.reserve h2 { clear:both; position:relative; color:#fff; font-size: 14px; font-weight:normal; padding: 6px 10px; margin: 0 0 15px 0; background-color: #2b120e; border-radius: 10px;-webkit-border-radius: 10px;-moz-border-radius: 10px; border: 0px #2b120e solid;behavior:url(PIE.htc);}
.reserve p { padding: 0 10px 20px 10px; }

.mailform { margin: 0; font-size: 14px; color: #000000; border-collapse: separate; border-spacing: 10px;
*margin-left: 10px; /* IE7 */ }

.mailform td { text-align:left; vertical-align: middle; width: 400px; min-height:34px; padding: 8px 0px 8px 15px; }
.mailform th { text-align:left; vertical-align: middle; border-right: solid 1px #553520; width: 292px; min-height:34px; padding: 8px 15px 8px 0; font-weight: normal; }

.mailform input, textarea { vertical-align: middle; padding: 0px; margin: 0px 3px 4px 3px; }
.mailform select { vertical-align: top; padding: 0px; margin: -3px 3px 0px 3px; }

.mailform .red { float: right; color: red; }
.mailform .red2 { color: red; letter-spacing: 2px; }
.mailform .small-font { font-size: 11px; padding: 0px 0px 0px 5px; }
.mailform .askspan01 input {  margin: 0px 3px 3px 0px; padding: 0px 5px 0px 5px; }







