@charset "utf-8";

/* =Reset default browser CSS.
Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */
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, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {border: 0;font-family: inherit;font-size: 100%;font-style: inherit;font-weight: inherit;margin: 0;outline: 0;padding: 0;vertical-align: baseline;}
:focus {outline: 0;}

ol, ul {list-style: none;}
table {border-collapse: separate;border-spacing: 0;}
caption, th, td {font-weight: normal;text-align: left;}
blockquote:before, blockquote:after,q:before, q:after {content: "";}
blockquote, q {quotes: "" "";}
a img {border: 0;}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display: block;}

body{
font:110%/1.5 "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
color:#252525;
background-color: #f7e6e6; /* ←これ */
padding-bottom: 75px;
}


/* リンク設定
------------------------------------------------------------*/
a{
margin:0;
padding:0;
text-decoration:none;
outline:0;
vertical-align:baseline;
background:transparent;
font-size:100%;
color:#624e24;
}

a:hover, a:active{
-webkit-transition:opacity 1s;-moz-transition:opacity 1s;-o-transition:opacity 1s;
outline: none;
color:#777;
}


/**** Clearfix ****/
.nav .panel:before,nav .panel:after, #mainNav:before,#mainNav:after, .newsTitle:before,.newsTitle:after{content: ""; display: table;}
nav .panel:after,#mainNav:after,.newsTitle:after{clear: both;}
nav .panel,#mainNav,.newsTitle{zoom: 1;}


/* フォーム
------------------------------------------------------------*/
input[type="text"], input[type="email"],textarea{
vertical-align:middle;
max-width:90%;
line-height:30px;
height:30px;
padding:1px 5px;
border:1px solid #d4d4d7;
border-radius:3px;
-webkit-border-radius:3px;
-moz-border-radius:3px;
font-size:100%;
color:#555;
background:#fcfcfc;
}

textarea{
height:auto;
line-height:1.5;
}

input[type="submit"],input[type="reset"],input[type="button"]{
padding:1px 10px;
border:1px solid #b3424a;
border-radius:3px;
-webkit-border-radius:3px;
-moz-border-radius:3px;
line-height:1.5;
font-size:100%;
color:#fff;
background:#b3424a;
}

input[type="submit"]:hover,input[type="reset"]:hover,input[type="button"]:hover{
color:#b3424a;
background: #fff;
cursor:pointer;
}

*:first-child+html input[type="submit"]{padding:3px;}


/* レイアウト
------------------------------------------------------------*/
#wrapper, .inner{
margin:0 auto;
width:940px;
}

#header,#mainNav{background:#fff;}

#header{overflow:hidden;}

#content{
float:right;
width:625px;
padding:30px 0;
}

#sidebar{
float:left;
width:265px;
padding:30px 0;
}

#footer{
clear:both;
padding-top:20px;
border-top:1px solid #ccc;
} 


/* ヘッダー
*****************************************************/

/* サイト説明文
----------------------------------*/
#header h1{
padding:10px 0 0 3px;
color: #000;
font-size:90%;
font-weight:normal;
}


/* ロゴ (サイトタイトル)
----------------------------------*/
#header h2{
clear:both;
float:left;
padding-top:20px;
color: #3c2f13;
font-size:160%;
font-weight:bold;
}


/* コンタクトインフォメーション
----------------------------------*/
#headerInfo{
float:right;
text-align:center;
}

#headerInfo p{
padding:2px 0 2px 0px;
color:#3c2f13;
font-size:15px;
font-weight:bold;
}

#headerInfo p.tel{background:url(images/tel.png) no-repeat 0 4px;font-size:16px;}

#headerInfo p.address{background-image:url(images/address.png);}


/* トップページ　メイン画像
----------------------------------*/
#mainImg{
line-height:0;
text-align:center;
background:url(images/main_bg.png) no-repeat 50% 0; 
z-index:0;
}


/* タイポグラフィ */
/* ***************************************************** */
/* h2.title および h2.first のエンジ色矩形化 */
h2.title{
clear:both;
margin:70px 0 20px;
padding: 10px 15px; /* 上下左右のパディングを増やし、矩形にする */
font-size:110%;
font-weight: bold; /* テキストを太字にする */
color: #fff; /* 文字色を白にする */
background: #b3424a; /* 背景色をエンジにする */
border-bottom: none; /* 元のCSSのボーダーを削除 */
border-radius: 5px; /* 角を少し丸くする（任意） */
/* 矩形に立体感を出すためのボックスシャドウ */
box-shadow: 0 4px 0 #8c343b; /* 下に濃いめの影（エンジより少し暗い色） */
/* 文字に立体感を出すためのテキストシャドウを強化 */
/* 影のオフセットを大きくし、より濃い影（#702a30）を追加して強調 */
text-shadow: 
    2px 2px 0 #8c343b,   /* 影を右下に移動（より立体的に） */
    3px 3px 0 #702a30;   /* さらに濃い影を重ねてくっきりさせる */
}

/* h2.title:hover {
box-shadow: 0 2px 0 #8c343b;
transform: translateY(2px);
} */

h2.first{
margin-top:0; /* 元のプロパティを保持 */
}

.dateLabel{
margin:-10px 0 10px;
text-align:right;
font:italic 1em "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

.post ul{margin: 0 0 10px 10px;}

.post ul li{
margin-bottom:5px;
padding-left:15px;
background:url(images/bullet.png) no-repeat 0 8px;
}

.post ol{margin: 0 0 10px 30px;}

.post ol li{list-style:decimal;}

.post h1{
margin:20px 0;
padding:5px 0;
font-size:150%;
color: #252525;
border-bottom:3px solid #3c2f13;
}



.post h3{
margin:30px 0 15px;
font-size:120%;
font-weight:normal;
color:#2e2c2c;
border-bottom:3px solid #3c2f13;
}

.post blockquote {
clear:both;
padding:10px 0 10px 15px;
margin:10px 0 25px 30px;
border-left:5px solid #ccc;
}
 
.post blockquote p{padding:5px 0;}

.post table{
border: 1px #2e2c2c solid;
border-collapse: collapse;
border-spacing: 0;
margin:10px 0 20px;
width: 100%;
}

.post table th{
padding:7px 10px 7px 5px;
border: #2e2c2c solid;
border-width: 0 0 1px 1px;
font-weight:bold;
background:#eff1f0;
}

.post table td{
padding:7px 5px;
border: 1px #2e2c2c solid;
border-width: 0 0 1px 1px;
background:#fff;
}

.post dt{font-weight:bold;}

.post dd{padding-bottom:10px;}

#content img{max-width:100%;height:auto;}

img.aligncenter {
display: block;
margin:5px auto;
}

img.alignright, img.alignleft{
padding:4px;
margin:0 0 2px 7px;
display:inline;
}

img.alignleft{margin: 0 7px 2px 0;}

.alignright{float:right;}
.alignleft{float: left;}



/* サイドバー　ウィジェット
*****************************************************/
.widget{
padding-bottom:20px;
margin-bottom:20px;
}

.widget h3{
clear:both;
margin:0 0 10px;
padding:5px 0;
font-size:100%;
font-weight:normal;
color: #252525;
border-bottom:3px solid #3c2f13;
}

.widget li{
margin: 0 10px 10px 5px;
border-bottom: 1px dotted #ccc;
}

.widget a{
display:block;
padding-left:15px;
background:url(images/arrow.png) no-repeat 0 50%;
}

.widget a:hover{background-position: 3px 50%;}

p.banner{padding-bottom:15px;}

#contactBanner{
width:265px;
height:50px;
padding-top:110px;
background:url(images/banners/banner_tel.jpg) no-repeat;
}

#contactBanner p.tel{
display:inline;
padding-left:80px;
margin-left:30px;
text-align:center;
font-weight:bold;
background:url(images/tel.png) no-repeat;
}

#searchform input[type="text"]{
line-height:1.7;
height:24px;
width:140px;
vertical-align:bottom;
}


/* 更新情報
-------------*/
.newsTitle{
clear:both;
margin:15px 0 20px;
padding:5px 0;
font-size:100%;
color: #252525;
border-bottom:3px solid #3c2f13;
}

.newsTitle h3{
float:left;
font-weight:normal;
}

.newsTitle p{
float:right;
padding:0 0 0 10px;
font-size:.8em;
background:url(images/arrow.png) no-repeat 0 50%;
}

.news{padding-bottom:40px;}

.news p{
clear:both;
padding-bottom:2px;
border-bottom: 1px dotted #ccc;
}

.news p a{
display:block;
padding:5px 0;
color:#252525;
font-style:italic;
font:italic 110% "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

.news a span{
color:#777;
font:normal 90% Arial, 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック',sans-serif;
}

.news span{padding-left:10px;}

.news a:hover span{color:#777;}



/* フッター
*****************************************************/
#footerLogo{
float:left;
width:265px;
}

#footerLogo img{
max-width:265px;
height:auto;
}

#footer ul{
float:right;
width:625px;
font-size:95%;
padding-bottom:20px;
}

#footer ul ul{padding-bottom:0;width:auto;}

#footer ul li{
display:inline-block;
vertical-align:text-top;
text-align:left;
padding:5px 0;
margin-left:15px;
background:url(images/arrow.png) no-repeat 0 9px;
}

#footer ul li	a{
display:block;
padding:0 0 0 12px;
overflow:hidden;
}

#footer ul li	a:hover{text-decoration:underline;}

#footer ul li li{
display:block;
padding:0;
margin-left:5px;
background:url(images/arrow2.png) no-repeat 0 6px;
}

#footer ul li	li a{padding:0 0 0 8px;}

*:first-child+html #footer ul li{display:inline;}
*:first-child+html #footer ul ul,*:first-child+html #footer ul li li a,*:first-child+html #footer ul li li{display:none;}

#copyright{
clear:both;
padding:5px;
text-align:center;
font-style:normal;
font-size:85%;
zoom:1;
}


/* page navigation
------------------------------------------------------------*/
.pagenav{
clear:both;
width:100%;
height:30px;
margin:5px 0 20px;
}

.prev{float:left}

.next{float:right;}

#pageLinks{
clear:both;
color:#4f4d4d;
text-align:center;
}


/* トップページ 最新記事3件 + お勧め商品
------------------------------------------------------------*/
.thumbWrap{
width:645px;
margin-right:-20px;
}

.thumbWrap li{
float:left;
width: 195px;
margin:0 20px 0 0;
padding:2px 0 40px;
background:none;
}

.thumbWrap img{max-width:100%;height:auto;}


/* 最新記事リンク */
ul.thumb h3{
margin-top:10px;
padding:1px;
font-weight:normal;
font-size:100%;
text-align:center;
background:#fff;
border:1px solid #bcbcbc;
}

ul.thumb h3 span{
display:block;
padding:2px 3px;
background:#b3424a;
color:#fff;
}

ul.thumb h3:hover{background:#f3f3f3;}
ul.thumb h3:hover span{background:#fff;color:#000;}

/* メインメニュー　PC用
------------------------------------------------------------*/
@media only screen and (min-width: 1025px){
#mainNav{
clear:both;
padding:15px 0 10px;
position:relative;
z-index:200;
background:#b3424a;
}

#mainNav ul{
background:url(images/sep.png) no-repeat 50% 50%;
}

#mainNav li{
float:left;
position:relative;
padding:0 15px 0 15px;
height:40px;
line-height:40px;
background:url(images/sep.png) no-repeat 100% 50%;
}

#mainNav li a{
display:block;
text-align:center;
_float:left;
color:#fff;
padding:0 15px;
font-weight: bold; /* ここに追加 */
}

#mainNav li.current-menu-item a, #mainNav li a:hover, #mainNav li a:active, #mainNav li.current-menu-parent a{
background:#fff;
border-radius:6px;
-webkit-border-radius:6px;
-moz-border-radius:6px;
color:#000;
}

#mainNav ul ul{width:160px;}

#mainNav li ul{display:none;}

#mainNav li li{
float:none;
height:40px;
line-height:40px;
width:160px;
padding:0;
}

#mainNav li:hover ul{
display:block;
position:absolute;
top:40px;
left:-7px;
z-index:500;
}

#mainNav li li a{
width:100%;
height:40px;
padding:0;
line-height:40px;
font-size:95%;
text-align:left;
}

#mainNav li li a span{padding:0 10px;}

#mainNav li li a:hover,#mainNav li li.current-menu-item a{color:#000;}

#mainNav li:hover li{
margin:0;
background:#b3424a;
border-bottom:1px solid #FFF;
color:#000;
-webkit-border-radius:6px;
-moz-border-radius:6px;
}

#mainNav li:hover li:last-child{
border:0;
border-radius:0 0 6px 6px;
-webkit-border-radius:6px;
-moz-border-radius:6px;
}

nav div.panel{
display:block !important;
float:left;
}
  
a#menu{display:none;}
}

/* メインメニュー iPadサイズ以下から
------------------------------------------------------------*/
@media only screen and (max-width:1024px){
	#mainNav{
	clear:both;
	width:100%;
	margin:0 auto;
	padding:20px 0;
	}
	
	#mainNav .inner{width:98%;}
	
	#mainNav a.menu{
	width:100%;
	display:block;
	height:40px;
	line-height:40px;
	font-weight: bold;
	text-align:left;
	color:#fff;
	border:1px solid #ccc;
  background:#b3424a url(images/menuOpen.png) no-repeat 5px 10px;
	}
	
	#mainNav a#menu span{padding-left:2.5em;}
	
	#mainNav a.menuOpen{
	border-bottom:0;
	color:#fff;
	background:#b3424a url(images/menuOpen.png) no-repeat 5px -32px;
	}
	
	#mainNav a#menu:hover{cursor:pointer;}
	
	nav .panel{
	display: none;
	width:100%;
	position: relative;
	right: 0;
	top:0;
	z-index: 1;
	border:1px solid #ccc;
	}

	.panel ul{margin:0;padding:0;}

	.panel ul li{
	float: none;
	clear:both;
	width:100%;
	height:auto;
	line-height:1.2;
	}

	.panel ul li a,.panel ul li.current-menu-item li a{
	display: block;
	width:100%;
	padding:1em 0;
	text-align:left;
	color:#b3424a;
	background:#fff;
	}

 .panel ul li a span{padding-left:1em;}
 
	.panel ul li.current-menu-item a,.panel ul li a:hover,.panel ul li.current-menu-item a,.panel ul li a:active, .panel ul li li.current-menu-item a, .panel ul li.current-menu-item li a:hover, .panel ul li.current-menu-item li a:active{
	color:#fff;
	background:#b3424a;
	}

	.panel ul li li{
	float:left;
	border:0;
	}

	.panel ul li li a, .panel ul li.current-menu-item li a, .panel ul li li.current-menu-item a{background:#fff url(images/sub1.png) no-repeat 20px 18px;}

	.panel ul li li.current-menu-item a,.panel ul li li a:hover, .panel ul li.current-menu-item li a:hover{background:#b3424a url(images/sub1.png) no-repeat 20px -60px;}
	
	.panel ul li li:last-child a{background:#fff url(images/subLast.png) no-repeat 20px 20px;}
	.panel ul li li:last-child.current-menu-item a,.panel ul li li:last-child a:hover,.panel ul li.current-menu-item li:last-child a:hover{background:#b3424a url(images/subLast.png) no-repeat 20px -65px;}

	.panel ul li li a span{padding-left:35px;}
	
	nav div.panel{float:none;}
	
	#mainImg{margin-bottom:20px;background-image:none;}
}


/* 959px以下から 1カラム表示
------------------------------------------------------------*/
@media only screen and (max-width: 959px){
  #wrapper, #header, .inner{width:100%;}

	#header h1, #header h2{padding:10px;}
	#headerInfo{padding-right:10px;}

	.panel ul, .thumbWrap{margin:0 auto;}
	.panel ul ul{padding:0;}

	nav div.panel{float:none;}
	
	#mainImg img{width:98%;height:auto;}

	#content, #sidebar{
	clear:both;
	width:95%;
	float:none;
	margin:0 auto;
	padding:10px 0;
	}
	
	#banners{width:100%;margin:0 auto;text-align:center;}
	#banners p{width:30%; float:left;margin:0 1% 0 2%;}
  #banners p img{width:100%;height:auto;}
	
	.widget_search{text-align:center;}
  #contactBanner{margin:0 auto;}

	#footer{margin:0;border:0;text-align:center;}
	
	#footerLogo, #footer ul{
	float:none;
	width:auto;
	padding-bottom:20px;
	text-align:center;
	}
	
	#footer ul{
	padding-top:20px;
	border-top:1px solid #ccc;
	}
	
	#footer ul ul{padding-top:0;border:0;}	
}


/* 幅648px以下から  トップページの３画像調節
------------------------------------------------------------*/
@media only screen and (max-width: 648px){
	.thumbWrap{width:100%;margin:0 auto;text-align:center;}
	.thumbWrap ul.thumb li{width:30%; float:left;margin:0 1% 0 2%;}
}


/* 幅644px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 644px){
	#header{width:98%;padding:0 1%;text-align:center;}
	#header h2,#footerLogo,#headerInfo{float:none;padding:0;}
	#headerInfo{width:250px;margin:0 auto;}
	img.alignright, img.alignleft{display:block;margin:5px auto;padding:0;}
	.alignright,.alignleft{float:none;}
	#footer ul{text-align:left;padding:15px;}
	#footer ul ul{padding:0;}
}



/* 強調タグの太字を確実にするための追加 */
strong, b {
    font-weight: bold;
}



.text-box {
  /* ... 既存のスタイル ... */

  /* ★★★ この一行を追加して、ボックスモデルを修正します ★★★ */
  box-sizing: border-box; 
  
  /* 背景を白にして、色味のある背景とのコントラストを確保 */
  background-color: white; 
  
  /* 最大幅を親要素に合わせる */
  max-width: 100%; 
  width: 100%; 
  
  /* 視認性を保ちつつ、角丸を適用 */
  border-radius: 5px; 
  
  /* 最小限の内部余白 (padding) */
  /* 上下: 8px、左右: 10px */
  padding: 8px 10px; 
  
  /* 最小限の外部余白 (margin) */
  /* 上下: 8px、左右: 0 */
  margin: 8px 0; 
  
  /* 文字色を濃い色に設定 */
  color: #333; 
  
  /* ボックスが浮き立って見えるよう、薄い影を追加 */
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); 
}


.hero-section {
    /* サイズ設定 (レスポンシブ対応) */
    width: 80%; /* 画面幅の80%を使用 */
    max-width: 1090px; /* 最大幅は1090pxに制限 */
    height: 250px;
    
    /* 左右中央揃え */
    margin: 0 auto; /* 左右のマージンを自動で設定し、中央に配置 */
    
    /* 背景画像の設定 */
    background-image: url("images/titleback.jpg"); 
    background-size: cover; /* コンテナを完全に覆うように画像を拡大・縮小 */
    background-position: center; /* 画像を中央に配置 */
    background-repeat: no-repeat; 

    /* Flexboxを使って子要素（テキスト）を中央に配置 */
    display: flex;
    justify-content: center; /* 水平方向の中央揃え */
    align-items: center; /* 垂直方向の中央揃え */
}


.hero-section2 {
    /* サイズ設定 (レスポンシブ対応) */
    width: 80%; /* 画面幅の80%を使用 */
    max-width: 1090px; /* 最大幅は1090pxに制限 */
    height: 250px;
    
    /* 左右中央揃え */
    margin: 0 auto; /* 左右のマージンを自動で設定し、中央に配置 */
    
    /* 背景画像の設定 */
    background-image: url("images/titleback2.jpg"); 
    background-size: cover; /* コンテナを完全に覆うように画像を拡大・縮小 */
    background-position: center; /* 画像を中央に配置 */
    background-repeat: no-repeat; 

    /* Flexboxを使って子要素（テキスト）を中央に配置 */
    display: flex;
    justify-content: center; /* 水平方向の中央揃え */
    align-items: center; /* 垂直方向の中央揃え */
}



/* ページ見出しの文言 (レスポンシブ対応) */
.page-title {
    /* 大き目のフォントサイズ */
    font-size: 2.5rem; /* rem単位で相対的なサイズを設定 */
    font-weight: bold;
    color: #ffffff; 
    text-align: center;
    
    /* テキストの視認性を高めるための影 */
    text-shadow: 2px 2px 4px #000000;
}

/* スマートフォンなど、画面幅が狭い場合の調整 (メディアクエリ) */
@media (max-width: 600px) {
    .hero-section {
        width: 95%; /* 狭い画面では幅を広めに使う (95%) */
        height: 150px; /* 高さを低くして見やすくする */
    }
    .hero-section2 {
        width: 95%; /* 狭い画面では幅を広めに使う (95%) */
        height: 150px; /* 高さを低くして見やすくする */
    }
    .page-title {
        font-size: 1.5rem; /* フォントサイズも小さく調整 */
    }
}


/* ========================================================== */
/* id="content" 内のリンクをデフォルトの青文字・下線ありに戻す */
/* ========================================================== */

/* 本文内のリンクを青色、下線ありに設定 */
#content a {
    color: blue; /* デフォルトに近い色 */
    text-decoration: underline; /* 下線を表示 */
}

/* ホバー時の設定 (グローバルのa:hoverを上書きし、色と下線を維持) */
#content a:hover {
    color: blue;
    text-decoration: underline;
    /* グローバルで設定されているopacityのトランジションを無効化 */
    -webkit-transition: none; 
    -moz-transition: none;
    -o-transition: none;
    opacity: 1; 
}


/* 黄色背景で太文字のスタイル */
.highlighted-text {
  /* 背景を黄色に設定 */
  background-color: yellow;
  
  /* 文字を太字に設定 */
  font-weight: bold;
  
  /* テキストの周りに余白（パディング）を少なめに設定 */
  padding: 2px 0;
}