@charset "UTF-8";
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);
.cf { zoom: 1; /* for ie */ }
.cf:after { content: ""; display: table; clear: both; }

body { font-size: 16px; line-height: 1.5; font-family: 'Noto Sans JP',"メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic",Helvetica,sans-serif; text-align: left; background: #fff; color: #333; min-width: 1160px; -webkit-text-size-adjust: 100%; }
@media screen and (max-width: 480px) { body { font-size: 14px; margin-top: 60px; max-width: 480px; min-width: auto; } }

a { color: #333; display: block; text-decoration: none; text-underline-offset: .2em; text-decoration-thickness: 1px; -webkit-transition: all 0.3s ease; -moz-transition: all 0.3s ease; -ms-transition: all 0.3s ease; -o-transition: all 0.3s ease; transition: all 0.3s ease; }
a:hover { color: #ff0066; }
a:hover i { -ms-transform: rotate(360deg); -webkit-transform: rotate(360deg); transform: rotate(360deg); }
a i { margin-right: 5px; -webkit-transition: all 0.3s; -moz-transition: all 0.3s; -ms-transition: all 0.3s; -o-transition: all 0.3s; transition: all 0.3s; }
@media screen and (max-width: 480px) { a i { margin-right: 3px; } }

img { max-width: 100%; vertical-align: bottom; }

/*---------------------------------------
Header
---------------------------------------*/
@media screen and (max-width: 480px) { #header { display: none; } }
#header .header-in { width: 1160px; margin: 0 auto; position: relative; height: 140px; }
@media screen and (max-width: 480px) { #header .header-in { width: 100% !important; } }
#header .header-in:after { content: ""; display: block; clear: both; }
#header .ichigo { position: absolute; bottom: 0; width: 90px; }
#header h1 { position: absolute; left: 100px; top: 15px; font-size: 0.8em; }
#header .company { position: absolute; left: 100px; bottom: 15px; background: url(../img/stb.jpg) no-repeat center left; background-size: 24px; padding-left: 34px; font-size: 0.8em; }
#header .logo { width: 400px; position: absolute; left: 100px; top: 45px; }
#header .contact { position: absolute; right: 0; top: 20px; }
#header .contact:after { content: ""; display: block; clear: both; }
#header .contact .tel { float: left; }
#header .contact .tel a { font-size: 38px; font-weight: bold; background: url(../img/icon_free.svg) no-repeat left center; background-size: 24px; padding-left: 34px; line-height: 1.2; font-family: Helvetica,sans-serif; }
#header .contact .tel span { font-size: 12px; }
#header .contact .mail { float: left; margin-left: 15px; }
#header .contact .mail a { text-align: center; font-size: 1.2em; padding: 15px 30px; background: #1F8CE6; color: #fff; line-height: 1; -webkit-border-radius: 60px; -moz-border-radius: 60px; -ms-border-radius: 60px; -o-border-radius: 60px; border-radius: 60px; }
#header .contact .mail a span { margin-top: 10px; display: block; font-size: 0.8em; padding-left: 5px; }
#header .contact .mail a i { margin-right: 10px; }
#header .contact .mail a:hover { text-decoration: none; }
#header .subNavi { position: absolute; right: 0; bottom: 15px; text-align: right; }
#header .subNavi li { float: left; margin-left: 20px; }
#header .subNavi li a { font-size: 0.8em; text-decoration: underline; }

.icon-line { background: url(../img/icon_line.png) no-repeat left center; background-size: 14px; padding-left: 24px; }

.global { clear: both; background: #ff5c93; }
.global .global-in { width: 1160px; margin: 0 auto; }
.global .global-in:after { content: ""; display: block; clear: both; }
@media screen and (max-width: 480px) { .global .global-in { width: 100% !important; } }
.global .global-in .menu { clear: both; float: left; }
.global .global-in .menu:after { content: ""; display: block; clear: both; }
.global .global-in .menu li { float: left; }
.global .global-in .menu li:hover { cursor: pointer !Important; }
@media screen and (max-width: 480px) { .global .global-in .menu li { width: 50%; } }
.global .global-in .menu li a { background: #ff5c93; color: #fff; text-align: center; padding: 15px; }
.global .global-in .menu li a:hover { background: #ff0066; text-decoration: none; }
.global .global-in .keywords { float: right; padding: 10px 15px 10px 0; text-align: center; position: relative; }
.global .global-in .keywords input { height: 36px; }
.global .global-in .keywords input[type="text"] { width: 220px; padding: 0 15px; border: none; position: relative; z-index: 1; font-size: 1em; box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.2) inset; -webkit-border-radius: 60px; -moz-border-radius: 60px; -ms-border-radius: 60px; -o-border-radius: 60px; border-radius: 60px; }
.global .global-in .keywords input[type="submit"] { position: absolute; right: 15px; top: 10px; z-index: 10; width: 48px; font-size: 18px; font-family: "Font Awesome 6 Pro"; font-weight: bold; background: none; border: none; color: #1F8CE6; }
.global .global-in .keywords input[type="submit"]:hover { cursor: pointer; }
.global .global-in .search { float: right; width: 160px; }
.global .global-in .search label { padding: 15px 0px; text-align: center; font-weight: bold; cursor: pointer; transition: .3s; display: block; background: #ff0066; color: #fff; }
.global .global-in .search label:after { display: inline-block; content: "\f078"; font-family: "Font Awesome 6 Pro"; padding-left: 5px; transition: 0.2s; }
@media screen and (max-width: 480px) { .global .global-in .search label { width: 100%; display: block; } }
.global .global-in .search input:checked + label:after { content: "\f077"; -ms-transform: rotate(360deg); -webkit-transform: rotate(360deg); transform: rotate(360deg); }
.global .global-in .search input#search-check { display: none; }
.global .global-in .search .search-menu { z-index: 1000; position: absolute; right: 0; width: 100%; height: 0; opacity: 0; padding: 0; overflow: hidden; transition: 0.3s; background: url(../img/search-menu_bg.png); color: #fff; }
.global .global-in .search .search-menu .search-menu-in { width: 1160px; margin: 0 auto; }
@media screen and (max-width: 480px) { .global .global-in .search .search-menu .search-menu-in { width: 100% !important; } }
.global .global-in .search .search-menu .search-menu-in:after { content: ""; display: block; clear: both; }
.global .global-in .search .search-menu .search-menu-in .search-menu-in-in { float: right; width: 800px; }
@media screen and (max-width: 480px) { .global .global-in .search .search-menu .search-menu-in .search-menu-in-in { width: 100%; } }
.global .global-in .search .search-menu .search-menu-in .search-menu-in-in .keyword { padding-top: 30px; }
.global .global-in .search .search-menu a { color: #fff; }
.global .global-in .search input:checked + label + .search-menu { height: auto; opacity: 1; padding: 10px 0; }

.sp-header { display: none; }
@media screen and (max-width: 480px) { .sp-header { display: block; position: absolute; top: 0; background: #ff5c93 url(../img/ichigo-beer.png) no-repeat top -8px left 0px; background-size: 60px; border-bottom: 1px solid #ff0066; width: 100%; height: 60px; z-index: 9999; }
  .sp-header h1 { position: absolute; top: 7px; left: 70px; font-size: 10px; color: #fff; }
  .sp-header .logo { position: absolute; top: 25px; left: 70px; }
  .sp-header .logo img { width: 240px; } }
@media screen and (max-width: 480px) and (max-width: 320px) { .sp-header .logo img { width: 180px; } }

/*---------------------------------------
Drawer // ドロワーメニュー
---------------------------------------*/
.sd-trigger, .sd-close { position: absolute; top: 0; right: 0; background: #ff0066; height: 50px; text-align: center; z-index: 999; }
.sd-trigger i, .sd-trigger span, .sd-close i, .sd-close span { display: block; color: #fff; }
.sd-trigger i, .sd-close i { font-size: 20px; margin-bottom: 3px; }
.sd-trigger span, .sd-close span { font-size: 12px; }

.sd-trigger { padding: 10px 4px 0 4px; border-left: 1px solid #D70056; }

.sd-close { width: 60px; padding: 10px 0 0 0; background: #666; }
.sd-close i, .sd-close span { color: #fff; }

#sd-menu { width: 400px; height: 100%; overflow: auto; position: fixed; right: -400px; top: 0; z-index: 9999; transition: transform 0.1s ease-out; background: #fff; background: #f5f5f5; }
@media screen and (max-width: 480px) { #sd-menu { width: 360px; right: -360px; } }
#sd-menu.block { transform: translate3d(-480px, 0, 0); }
@media screen and (max-width: 480px) { #sd-menu.block { transform: translate3d(-360px, 0, 0); } }
#sd-menu h2.sd-title { height: 60px; line-height: 60px; padding: 0 10px; font-size: 1.2em; background: #ff0066; color: #fff; border-bottom: 1px solid #D70056; }
@media screen and (max-width: 480px) { #sd-menu h2.sd-title { font-size: 1em; } }
#sd-menu .buttons .tel, #sd-menu .buttons .mail, #sd-menu .buttons .home { position: absolute; border-right: 1px solid #D70056; }
#sd-menu .buttons .tel a, #sd-menu .buttons .mail a, #sd-menu .buttons .home a { color: #fff; width: 60px; height: 50px; padding-top: 10px; text-align: center; }
#sd-menu .buttons .tel a i, #sd-menu .buttons .mail a i, #sd-menu .buttons .home a i { display: block; color: #fff; font-size: 20px; margin-bottom: 2px; }
#sd-menu .buttons .tel a span, #sd-menu .buttons .mail a span, #sd-menu .buttons .home a span { font-size: 12px; }
#sd-menu .buttons .tel { right: 120px; top: 0; }
#sd-menu .buttons .mail { right: 60px; top: 0; }
#sd-menu .buttons .home { right: 180px; top: 0; border-left: 1px solid #D70056; }
#sd-menu .form-keyword { margin: 10px; }

#sd-overlay { width: 100%; height: 100%; position: fixed; left: -100%; top: 0; z-index: 9; transition: 0.3s; opacity: 0; background: rgba(0, 0, 0, 0.5); }
#sd-overlay.block { left: 0; opacity: 1; }

/*---------------------------------------
box-search
---------------------------------------*/
.box-search .section { padding: 0; }
.box-search .section:after { content: ""; display: block; clear: both; }
@media screen and (max-width: 480px) { .box-search .section dl:last-child { border-bottom: 1px solid #ddd; } }
.box-search h2.title { font-weight: bold; margin-bottom: 0px !important; padding: 15px 0; text-align: center; border-top: 3px solid #ff0066; border-left: 0; border-bottom: #ddd 1px solid; font-size: 1.6em; }
.box-search h2.title i { margin-right: 5px; }
@media screen and (max-width: 480px) { .box-search h2.title { font-size: 1.2em; }
  .box-search h2.title span { display: inline-block; } }
.box-search h3.title { margin-bottom: 15px; padding: 0 0 10px 34px; font-size: 1.2em; font-weight: bold; border-bottom: 1px solid #ddd; }
@media screen and (max-width: 480px) { .box-search h3.title { margin: 10px; } }
.box-search .japan .title { background: url(../img/icon-japan.png) no-repeat top 5px left; background-size: 24px; }
.box-search .onsen .title { background: url(../img/icon-onsenflag.png) no-repeat top 5px left; background-size: 24px; }
.box-search .kodawari .title { background: url(../img/icon-kodawari.png) no-repeat top 5px left; background-size: 24px; }
.box-search .page .title { background: url(../img/icon-page.png) no-repeat top 5px left; background-size: 24px; }
.box-search .company .title { background: url(../img/icon-company.png) no-repeat top 5px left; background-size: 24px; }
.box-search .type .title { position: relative; }
.box-search .type .title:before { color: #ff0066; position: absolute; left: 0px; top: 0px; content: "\f08a"; font-family: "Font Awesome 6 Pro"; font-weight: 400; }
.box-search .keyword form { margin-bottom: 15px; }
.box-search .keyword .title { background: none; position: relative; }
.box-search .keyword .title:after { position: absolute; left: 0; top: 3px; content: '\f004'; font-family: "Font Awesome 6 Pro"; color: #ff0066; }
.box-search .list-hotWord li { margin-right: 5px; display: inline-block; }
@media screen and (max-width: 480px) { .box-search .list-hotWord li { margin-bottom: 0px; } }
.box-search .list-hotWord li a { color: #fff !important; font-size: 14px; }
.box-search .list-hotWord li a::before { content: "#"; }
@media screen and (max-width: 480px) { .box-search .list-hotWord li a { font-size: 12px; } }
.box-search .list-keyword dt, .box-search .list-keyword dd { float: left; }
@media screen and (max-width: 480px) { .box-search .list-keyword dt, .box-search .list-keyword dd { float: none; font-size: 1.2em; } }
.box-search .list-keyword dt { margin-bottom: 10px; width: 20%; }
.box-search .list-keyword dt a { display: inline-block; }
@media screen and (max-width: 480px) { .box-search .list-keyword dt { width: 100%; margin-bottom: 0; padding: 10px 15px; color: #333; border-top: 1px solid #ddd; position: relative; box-sizing: border-box; }
  .box-search .list-keyword dt:hover { cursor: pointer; }
  .box-search .list-keyword dt:before { position: absolute; right: 15px; top: 10px; content: '\f067'; font-family: "Font Awesome 6 Pro"; color: #666; }
  .box-search .list-keyword dt.open:before { content: '\f068'; } }
.box-search .list-keyword dd { margin-bottom: 10px; width: 80%; }
@media screen and (max-width: 480px) { .box-search .list-keyword dd { width: 100%; margin-bottom: 0; display: none; } }
.box-search .list-keyword dd ul:after { content: ""; display: block; clear: both; }
.box-search .list-keyword dd ul li { float: left; }
.box-search .list-keyword dd ul li.big { font-weight: bold; }
@media screen and (max-width: 480px) { .box-search .list-keyword dd ul li { float: none; border-top: 1px solid #ddd; } }
.box-search .list-keyword dd ul li a { padding: 0 10px; border-right: 1px solid #ddd; text-decoration: none; }
@media screen and (max-width: 480px) { .box-search .list-keyword dd ul li a { padding: 10px 10px 10px 30px; position: relative; border-right: none; }
  .box-search .list-keyword dd ul li a:before { position: absolute; right: 15px; top: 10px; content: '\f054'; font-family: "Font Awesome 6 Pro"; color: #666; } }
.box-search .list-keyword dd ul li:last-child a { border-right: none; }
@media screen and (max-width: 480px) { .box-search .list-onsen, .box-search .list-kodawari { margin: 10px; } }
.box-search .list-onsen { margin-bottom: 1em; }
.box-search .list-onsen:after { content: ""; display: block; clear: both; }
.box-search .list-onsen li { margin-right: 5px; }
.box-search .list-onsen li a { position: relative; font-size: 14px; }
@media screen and (max-width: 480px) { .box-search .list-onsen li a { font-size: 12px; } }
.box-search .list-onsen li a .pic { z-index: 1; }
.box-search .list-onsen li a .pic img { margin-bottom: 5px; }
.box-search .kodawari .pickup { margin-bottom: 10px; }
.box-search .kodawari .pickup img { margin-bottom: 5px; }
@media screen and (max-width: 480px) { .box-search .kodawari .pickup { padding: 0 10px; } }
.box-search .kodawari .list-kodawari { overflow: hidden; margin-right: -1%; }
@media screen and (max-width: 480px) { .box-search .kodawari .list-kodawari { margin-right: 0; } }
.box-search .kodawari .list-kodawari li { width: 19%; margin-right: 1%; float: left; }
@media screen and (max-width: 480px) { .box-search .kodawari .list-kodawari li { width: 48%; margin-bottom: 5px; }
  .box-search .kodawari .list-kodawari li:nth-child(2n+1) { margin-right: 2%; } }
.box-search .kodawari .list-kodawari li a { font-size: 12px; }
.box-search .kodawari .list-kodawari li a img { margin-bottom: 5px; }
.box-search .description { font-size: 12px; margin-bottom: 15px; }
@media screen and (max-width: 480px) { .box-search .description { margin: 10px; } }
.box-search .list-type { display: flex; flex-wrap: wrap; }
.box-search .list-type li { width: calc(100% / 4 - 15px); margin-right: 15px; float: left; }
@media screen and (max-width: 480px) { .box-search .list-type li { width: calc(100% / 2 - 15px); margin: 0 0 0 10px; } }
.box-search .list-type li.pink .title { color: #ff0066; }
.box-search .list-type li.soft .title { color: #FF9900; }
.box-search .list-type li.cos .title { color: #FFcc00; }
.box-search .list-type li.normal .title { color: #0099FF; }
.box-search .list-type li a .title { margin-bottom: 10px; }
.box-search .list-type li a .title:before { display: none; }
.box-search .list-type li a .pic { height: 160px; margin-bottom: 10px; border-radius: 6px; overflow: hidden; }
.box-search .list-type li a .text { font-size: 12px; line-height: 1.2; margin-bottom: 5px; font-weight: normal; }
.box-search .list-type li a .star { margin-bottom: 5px; font-size: 12px; }
.box-search .list-type li a .star dt, .box-search .list-type li a .star dd { display: inline; }
.box-search .list-type li a .star dd span { color: #ff0066; }
.box-search .list-type li a .btn, .box-search .list-type li a form.mailform input[type="submit"], form.mailform .box-search .list-type li a input[type="submit"], .box-search .list-type li a form.mailform button, form.mailform .box-search .list-type li a button { text-align: center; padding: 5px; border: 1px solid #fff; }
@media screen and (max-width: 480px) { .box-search .list-type li a { font-size: 0.8em; font-weight: bold; padding: 3px 0px; } }

.box-bnr ul li { margin-bottom: 15px; }
@media screen and (max-width: 480px) { .box-bnr ul li { margin-bottom: 10px; } }
.box-bnr ul li .pic { margin-bottom: 5px; }
.box-bnr ul li .text { font-size: 12px; line-height: 1; }

.box-award { background: #CC9900; }
.box-award ul { width: 1160px; margin: 0 auto; }
@media screen and (max-width: 480px) { .box-award ul { width: 100% !important; } }
.box-award ul:after { content: ""; display: block; clear: both; }
.box-award ul li { width: 20%; float: left; }
@media screen and (max-width: 480px) { .box-award ul li { width: 25%; } }

.list-ranking { border-top: 1px solid #ddd; margin-bottom: 30px; }
@media screen and (max-width: 480px) { .list-ranking { margin-bottom: 15px; } }
.list-ranking > li { padding: 15px; background: #fff; border-bottom: 1px solid #ddd; }
.list-ranking > li:after { content: ""; display: block; clear: both; }
@media screen and (max-width: 480px) { .list-ranking > li { padding: 10px; } }
.list-ranking > li .pic { width: 31%; float: left; margin-right: 3%; z-index: 1; position: relative; }
.list-ranking > li .text { width: 66%; float: left; line-height: 1.4; }
.list-ranking > li .text .name { font-size: 1.2em; margin-bottom: 5px; }
@media screen and (max-width: 480px) { .list-ranking > li .text .name { margin-bottom: 0px; } }
.list-ranking > li .text .list-rating { margin-bottom: 10px !important; }
@media screen and (max-width: 480px) { .list-ranking > li .text .list-rating { margin-bottom: 5px; } }
.list-ranking > li .text .list-rating .kuchikomi { color: #333; text-decoration: none; }
.list-ranking > li .text .catch { margin-bottom: 10px; font-size: 0.8em; }
@media screen and (max-width: 480px) { .list-ranking > li .text .catch { margin-bottom: 5px; } }
.list-ranking > li .text ul.kuchikomi li { padding: 5px 10px; margin-bottom: 7px; background: #f5f5f5; position: relative; }
.list-ranking > li .text ul.kuchikomi li:after { border-top: solid 7px transparent; border-bottom: solid 7px transparent; border-right: solid 10px #f5f5f5; left: -10px; content: ""; display: block; top: 30%; position: absolute; }

.list-rating > * { margin-right: 10px; display: inline-block; }
@media screen and (max-width: 480px) { .list-rating > * { margin-right: 5px; } }
.list-rating .title { margin-bottom: 5px; }
.list-rating .star img { width: 110px; vertical-align: top; }
@media screen and (max-width: 480px) { .list-rating .star img { width: 100px; } }
.list-rating .star .value { font-weight: bold; }
.list-rating .kuchikomi { position: relative; padding-left: 20px; }
.list-rating .kuchikomi:before { position: absolute; top: 0; left: 0; content: '\f27a'; font-family: "Font Awesome 6 Pro"; color: #ff0066; }
.list-rating .kuchikomi small { font-size: 12px; }
.list-rating .like { position: relative; padding-left: 20px; }
.list-rating .like i, .list-rating .like form, .list-rating .like div { display: inline-block; }
.list-rating .like::before { position: absolute; top: 0; left: 0; content: '\f164'; font-family: "Font Awesome 6 Pro"; color: #ff0066; }
.list-rating .like input { color: #1F8CE6; text-decoration: underline; cursor: pointer; margin: 0; padding: 0; border: none; background: none; text-shadow: none; box-shadow: none; font-size: 1em; }

/*---------------------------------------
HOME
---------------------------------------*/
.layout { width: 1160px; margin: 0 auto; }
@media screen and (max-width: 480px) { .layout { width: 100% !important; } }

.box-visual { background: url(../img/visual-pc.jpg) center no-repeat; background-size: cover; padding: 90px 0 90px; }
@media screen and (max-width: 480px) { .box-visual { background: url(../img/visual-sp.jpg) center no-repeat; background-size: cover; padding: 40px 0; } }
.box-visual .in { width: 1160px; margin: 0 auto; text-align: center; }
@media screen and (max-width: 480px) { .box-visual .in { width: 100% !important; } }
.box-visual .in .leadMain { font-size: 62px; font-weight: 700; color: #fff; background: url(../img/enjoy.png) no-repeat top center; padding-top: 60px; margin-bottom: 30px; text-shadow: 0px 0px 10px #666; -moz-text-shadow: 0px 0px 10px #666; -webkit-text-shadow: 0px 0px 10px #666; }
@media screen and (max-width: 480px) { .box-visual .in .leadMain { font-size: 24px; margin-bottom: 15px; padding-top: 50px; background-size: 200px; } }
.box-visual .in .leadSub { color: #fff; font-size: 1.6em; margin-bottom: 30px; }
@media screen and (max-width: 480px) { .box-visual .in .leadSub { font-size: 13px; padding: 0 10px; margin-bottom: 15px; } }
.box-visual .in form { margin-bottom: 30px; }
@media screen and (max-width: 480px) { .box-visual .in form { margin-bottom: 15px; font-size: 14px; } }

.box-homeTop { padding: 30px 0; }
.box-homeTop:after { content: ""; display: block; clear: both; }
@media screen and (max-width: 480px) { .box-homeTop { padding: 15px 0 !important; border-top: none !important; } }
.box-homeTop .section { margin-bottom: 15px; }
.box-homeTop .box-left { float: left; width: 820px; margin-right: 20px; }
@media screen and (max-width: 480px) { .box-homeTop .box-left { width: 100%; float: none; margin-bottom: 15px; } }
.box-homeTop .box-left .box-search { background: #fff; }
.box-homeTop .box-left .box-search .in { padding: 30px; }
@media screen and (max-width: 480px) { .box-homeTop .box-left .box-search .in { padding: 0px; } }
.box-homeTop .box-right { float: left; width: 320px; }
@media screen and (max-width: 480px) { .box-homeTop .box-right { width: auto; padding: 10px; float: none; } }
.box-homeTop .box-right .section h3 { margin-bottom: 10px; padding-bottom: 3px; border-bottom: 1px solid #ddd; font-weight: bold; }
.box-homeTop .box-right .post-new h4 { margin-bottom: 5px; }
.box-homeTop .box-right .post-new .date { font-size: 12px; }
.box-homeTop .box-right .post-ranking .list-post { counter-reset: number; }
.box-homeTop .box-right .post-ranking .list-post li { position: relative; }
.box-homeTop .box-right .post-ranking .list-post li:before { position: absolute; counter-increment: number; content: counter(number); background: #ff0066; color: #fff; display: inline-block; padding: 0 5px; font-size: 14px; text-align: center; }

.slider-pickup { overflow: hidden; margin-right: -15px; }
.slider-pickup li { margin-right: 15px; }

.list-post li { margin-bottom: 10px; }
.list-post li:after { content: ""; display: block; clear: both; }
.list-post li .pic, .list-post li .text { float: left; }
.list-post li .pic { width: 30%; margin-right: 3%; }
.list-post li .text { width: 67%; }
.list-post li .text h4 { line-height: 1.4; font-size: .9em; }

.ribbon { position: relative; }
.ribbon .rank { position: absolute; top: 0; left: 10px; margin: 0; padding: 20px 0 0; z-index: 2; width: 32px; text-align: center; color: #fff; }
.ribbon .rank:after { content: ''; position: absolute; left: 0; top: 100%; height: 0; width: 0; border-bottom: 10px solid transparent; }
.ribbon .rank01, .ribbon .rank02, .ribbon .rank03 { background-size: 16px; font-weight: bold; }
.ribbon .rank01 { background: #AE9436 url(../img/rank_01.png) no-repeat top 7px left 50%; background-size: 16px; }
.ribbon .rank01:after { border-left: 16px solid #AE9436; border-right: 16px solid #AE9436; }
.ribbon .rank02 { background: #6B6F7D url(../img/rank_02.png) no-repeat top 7px left 50%; background-size: 16px; }
.ribbon .rank02:after { border-left: 16px solid #6B6F7D; border-right: 16px solid #6B6F7D; }
.ribbon .rank03 { background: #9A6C46 url(../img/rank_03.png) no-repeat top 7px left 50%; background-size: 16px; }
.ribbon .rank03:after { border-left: 16px solid #9A6C46; border-right: 16px solid #9A6C46; }
.ribbon .rank04, .ribbon .rank05, .ribbon .rank06, .ribbon .rank07, .ribbon .rank08, .ribbon .rank09, .ribbon .rank010 { background: #f5f5f5; color: #333; padding: 3px 0; }
.ribbon .rank04:after, .ribbon .rank05:after, .ribbon .rank06:after, .ribbon .rank07:after, .ribbon .rank08:after, .ribbon .rank09:after, .ribbon .rank010:after { border-left: 16px solid #fff; border-right: 16px solid #fff; }

.boxTitle { text-align: center; font-size: 2em; margin-bottom: 30px; position: relative; font-weight: bold; }
@media screen and (max-width: 480px) { .boxTitle { font-size: 18px; margin-bottom: 30px; } }
.boxTitle:after { position: absolute; content: ""; background-image: linear-gradient(-90deg, #F6FF00 30%, #ff0066); width: 200px; height: 1px; bottom: -15px; left: 0; right: 0; margin: auto; }
@media screen and (max-width: 480px) { .boxTitle:after { top: 30px; } }

.boxSubtitle { font-size: 1.6em; margin-bottom: 30px; text-align: center; line-height: 1; }
@media screen and (max-width: 480px) { .boxSubtitle { margin-bottom: 15px; } }

.boxText { text-align: center; margin-bottom: 30px; }
@media screen and (max-width: 480px) { .boxText { margin-bottom: 5px; padding: 0 10px; font-size: 12px; } }

.boxSection { padding: 60px 0; }
@media screen and (max-width: 480px) { .boxSection { padding: 20px 0; } }
.boxSection .boxSection-in { width: 1160px; margin: 0 auto; }
@media screen and (max-width: 480px) { .boxSection .boxSection-in { width: 100% !important; } }

.boxGray { background: #f5f5f5; border-top: 1px solid #ddd; border-bottom: 1px solid #ddd; }

.section { margin-bottom: 30px; }
@media screen and (max-width: 480px) { .section { margin-bottom: 15px; } }

.list-bnr + .list-bnr li { margin-bottom: 0; }

.list-bnr { margin-right: -1%; }
.list-bnr:after { content: ""; display: block; clear: both; }
@media screen and (max-width: 480px) { .list-bnr { margin-right: 0; padding: 0 10px; } }
.list-bnr li { width: 24%; margin-bottom: 20px; margin-right: 1%; float: left; }
@media screen and (max-width: 480px) { .list-bnr li { width: 49%; margin-right: 0; margin-bottom: 10px; }
  .list-bnr li:nth-child(2n+1) { margin-right: 2%; } }
.list-bnr li .pic { margin-bottom: 10px; }
@media screen and (max-width: 480px) { .list-bnr li .pic { margin-bottom: 5px; } }
.list-bnr li .area { font-size: 12px; }
.list-bnr li .title { font-size: 14px; line-height: 1.2; margin-bottom: 5px; }
.list-bnr li .text { font-size: 12px; line-height: 1.4; color: #666; }

.col2, .col3, .col4 { display: flex; flex-wrap: wrap; }
@media screen and (max-width: 480px) { .col2, .col3, .col4 { display: block; } }
.col2 > li, .col2 .col, .col3 > li, .col3 .col, .col4 > li, .col4 .col { margin-bottom: 1rem; }

.col2 { margin-right: -3rem; }
@media screen and (max-width: 599px) { .col2 { margin-right: 0; } }
.col2 > .col { width: calc(100% / 2 - 3rem); margin-right: 3rem; }
@media screen and (max-width: 599px) { .col2 > .col { width: auto; margin-right: 0; } }

.col3 { margin-right: -2rem; }
@media screen and (max-width: 599px) { .col3 { margin-right: 0; } }
.col3 > .col { width: calc(100% / 3 - 2rem); margin-right: 2rem; }
@media screen and (max-width: 599px) { .col3 > .col { width: auto; margin-right: 0; } }

.col4 { margin-right: -1.5rem; }
@media screen and (max-width: 599px) { .col4 { margin-right: 0; } }
.col4 > .col { width: calc(100% / 4 - 1.5rem); margin-right: 1.5rem; }
@media screen and (max-width: 599px) { .col4 > .col { width: auto; margin-right: 0; } }

.box-cp { width: 1160px; margin: 0 auto; padding: 30px 0; }
@media screen and (max-width: 480px) { .box-cp { width: 100% !important; } }
@media screen and (max-width: 480px) { .box-cp { padding: 10px 0 0; } }

.list-bnrBig { margin-bottom: 10px; }
.list-bnrBig .pic { margin-bottom: 5px; }
@media screen and (max-width: 480px) { .list-bnrBig { margin: 0 10px 10px; } }

.list-flyer li { margin: 0 10px 0 0; height: 260px; }
@media screen and (max-width: 480px) { .list-flyer li { height: auto; } }

.box-ranking h3.title { font-size: 1.6em; background: url(../img/rank-title.png) left center no-repeat; background-size: 40px; padding: 5px 0 5px 50px; margin-bottom: 15px; }
@media screen and (max-width: 480px) { .box-ranking h3.title { font-size: 1.2em; background: url(../img/rank-title.png) left 10px center no-repeat; background-size: 40px; } }

.box-kuchikomi .pager:after { content: ""; display: block; clear: both; }
.box-kuchikomi .pager .prev { float: left; }
.box-kuchikomi .pager .next { float: right; }
.box-kuchikomi .pager .prev a#kuchikomi_prev_btn, .box-kuchikomi .pager .next a#kuchikomi_next_btn { padding: .75em 1em; border: 1px solid #ddd; -webkit-border-radius: 30px; -moz-border-radius: 30px; -ms-border-radius: 30px; -o-border-radius: 30px; border-radius: 30px; }

.box-rating { padding: 15px; margin-bottom: 15px; border: 1px solid #ddd; }
@media screen and (max-width: 480px) { .box-rating { padding: 10px; margin: 0 10px 10px; } }
.box-rating .star { margin-bottom: 10px; }
.box-rating .star img { width: 140px; margin: -10px 5px 0 5px; vertical-align: middle; }
@media screen and (max-width: 480px) { .box-rating .star img { width: 120px; } }
.box-rating .star .title { font-weight: bold; }
.box-rating .star .value { font-size: 24px; font-weight: bold; }
.box-rating table th, .box-rating table td { text-align: center; padding: 10px 0; line-height: 1.2; }
.box-rating table th { width: 19.9%; background: #ff5c93; font-weight: bold; }
.box-rating table td span { font-size: 24px; font-weight: bold; }
.box-rating .btn, .box-rating form.mailform input[type="submit"], form.mailform .box-rating input[type="submit"], .box-rating form.mailform button, form.mailform .box-rating button { display: block; max-width: 400px; margin-right: auto; margin-left: auto; margin-bottom: 0; }

.list-kuchikomi { margin-right: -15px; margin-bottom: 30px; }
.list-kuchikomi:after { content: ""; display: block; clear: both; }
@media screen and (max-width: 480px) { .list-kuchikomi { margin-right: 0; margin-bottom: 10px; } }
.list-kuchikomi li { margin-right: 15px; padding-top: 5px; width: 275px; float: left; }
@media screen and (max-width: 480px) { .list-kuchikomi li { float: none; width: auto; padding: 0 10px; margin-right: 0; margin-bottom: 10px; } }
.list-kuchikomi li a, .list-kuchikomi li .in { -webkit-taransition: all 0.2s; -moz-taransition: all 0.2s; -ms-taransition: all 0.2s; -o-taransition: all 0.2s; taransition: all 0.2s; background: #fff; padding: 20px; position: relative; margin-bottom: 20px; box-shadow: 0 2px 5px #ccc; -webkit-box-shadow: 0 2px 5px #ccc; -moz-box-shadow: 0 2px 5px #ccc; }
.list-kuchikomi li a:hover, .list-kuchikomi li .in:hover { -webkit-transform: translateY(-5px); -moz-transform: translateY(-5px); -ms-transform: translateY(-5px); -o-transform: translateY(-5px); transform: translateY(-5px); }
@media screen and (max-width: 480px) { .list-kuchikomi li a, .list-kuchikomi li .in { padding: 10px; } }
.list-kuchikomi li a .yado, .list-kuchikomi li .in .yado { padding-bottom: 15px; margin-bottom: 15px; border-bottom: 1px solid #ddd; }
@media screen and (max-width: 480px) { .list-kuchikomi li a .yado, .list-kuchikomi li .in .yado { padding-bottom: 7px; margin-bottom: 7px; } }
.list-kuchikomi li a .yado .area, .list-kuchikomi li .in .yado .area { font-size: 0.8em; }
.list-kuchikomi li a .content .title, .list-kuchikomi li .in .content .title { font-weight: bold; margin-bottom: 10px; }
.list-kuchikomi li .from { text-align: center; }
.list-kuchikomi li .from:after { content: ""; display: block; clear: both; }
.list-kuchikomi li .from li { display: inline-block; margin-right: 10px; }
@media screen and (max-width: 480px) { .list-kuchikomi li .from li { margin-right: 5px; } }
.list-kuchikomi li .from .name { margin-right: 5px; }
.list-kuchikomi li .from .name i { margin-right: 5px; }
@media screen and (max-width: 480px) { .list-kuchikomi li .from .name, .list-kuchikomi li .from .date { display: inline-block; } }
@media screen and (max-width: 480px) { .list-kuchikomi li .comment { font-size: 0.8em; } }

.box-area .list-area:after { content: ""; display: block; clear: both; }
@media screen and (max-width: 480px) { .box-area .list-area { padding: 10px; } }
.box-area .list-area > li { width: 50%; float: left; margin-bottom: 10px; }
@media screen and (max-width: 480px) { .box-area .list-area > li { width: auto; float: none; margin-bottom: 5px; } }
.box-area .list-area > li:after { content: ""; display: block; clear: both; }
.box-area .list-area > li a .text { line-height: 1.5; }
.box-area .list-area > li a .text:after { content: ""; display: block; clear: both; }
.box-area .list-area > li a .text:before { font-family: "Font Awesome 6 Pro"; content: "\f054"; font-size: .8em; display: inline-block; padding-right: 5px; }
@media screen and (max-width: 480px) { .box-area .list-area > li a .text { font-size: 0.8em; float: left; width: 73%; } }
.box-area .list-area > li a .text .name, .box-area .list-area > li a .text .area { display: inline-block; }
.box-area .list-area > li a .text .icon { display: none; }

/*---------------------------------------
Footer
---------------------------------------*/
#footer .menu { float: right; width: 330px; }
@media screen and (max-width: 480px) { #footer .menu { width: 100%; margin-right: 0; }
  #footer .menu a { font-size: 14px !important; } }
#footer .menu ul { border-top: 1px solid #ddd; }
#footer .menu ul li a { padding: 10px 15px; border-bottom: 1px solid #ddd; position: relative; }
@media screen and (max-width: 480px) { #footer .menu ul li a { font-size: 1.2em; } }
#footer .menu ul li a:before { position: absolute; right: 15px; content: '\f105'; font-family: "Font Awesome 6 Pro"; color: #333; }
#footer .box-search { float: left; width: 800px; }
@media screen and (max-width: 480px) { #footer .box-search { width: 100%; margin-right: 0; } }
#footer .box-search h2.title { margin-bottom: 20px !important; }
@media screen and (max-width: 480px) { #footer .box-search h2.title { margin-bottom: 0 !important; } }

.pc-contact { width: 100%; position: fixed; z-index: 9999; bottom: 0; background-color: rgba(255, 255, 255, 0.7); padding: 5px 0; }
.pc-contact .layout { position: relative; }
.pc-contact .girl { position: absolute; right: 0; bottom: -10px; width: 90px; }
.pc-contact .mail, .pc-contact .tel { float: left; width: 50%; line-height: 1; }
.pc-contact .tel > * { display: inline-block; }
.pc-contact .tel .free { width: auto; margin-right: 10px; }
.pc-contact .tel .free a { font-size: 42px; font-weight: bold; line-height: 1; font-family: Helvetica,sans-serif; }
.pc-contact .tel .free a:before { padding-right: 5px; content: '\f095'; font-family: "Font Awesome 6 Pro"; font-weight: 900; font-size: 32px; }
.pc-contact .tel .time { font-size: 13px; overflow: hidden; line-height: 1.4; }
.pc-contact .btn a, .pc-contact form.mailform input[type="submit"] a, form.mailform .pc-contact input[type="submit"] a, .pc-contact form.mailform button a, form.mailform .pc-contact button a { padding: 10px 0; font-size: 20px; background: #ff0066; border-bottom: 6px solid #D70056; }
@media screen and (max-width: 480px) { .pc-contact { display: none; } }

.sp-contact { display: none; }
@media screen and (max-width: 480px) { .sp-contact { width: 100%; display: block; position: fixed; bottom: 0; background-color: rgba(0, 0, 0, 0.7); padding: 5px 2%; /* 2/23/2/23/2/46/2 */ }
  .sp-contact .home, .sp-contact .tel, .sp-contact .mail { float: left; text-align: center; }
  .sp-contact .home a, .sp-contact .tel a, .sp-contact .mail a { -webkit-border-radius: 2px; -moz-border-radius: 2px; -ms-border-radius: 2px; -o-border-radius: 2px; border-radius: 2px; font-weight: bold; }
  .sp-contact .home { width: 23%; margin-right: 2%; }
  .sp-contact .home a { background: #fff; padding: 7px 0; }
  .sp-contact .home a:before { padding-right: 5px; content: '\f015'; font-family: "Font Awesome 6 Pro"; }
  .sp-contact .tel { width: 23%; margin-right: 2%; }
  .sp-contact .tel a { background: #ff0066; color: #fff; padding: 7px 0; }
  .sp-contact .tel a:before { padding-right: 5px; content: '\f095'; font-family: "Font Awesome 6 Pro"; }
  .sp-contact .mail { width: 46%; }
  .sp-contact .mail a { background: #ff0066; color: #fff; padding: 7px 0 7px 15px; text-align: left; }
  .sp-contact .mail a:before { padding-right: 5px; content: '\f0e0'; font-family: "Font Awesome 6 Pro"; }
  .sp-contact .op { position: fixed; right: -10px; bottom: 0; width: 60px; } }
@media screen and (max-width: 480px) and (max-width: 480px) { .sp-contact .op { width: 46px; } }

.copyright { background: #333; padding: 15px 0; color: #ddd; text-align: center; }
.copyright a { display: inline-block; color: #ddd; }

.box-company { clear: both; }
.box-company a { display: inline-block; }
@media screen and (max-width: 480px) { .box-company .info { padding: 0 10px; } }
.box-company .info .siteName { margin-bottom: 15px; }
@media screen and (max-width: 480px) { .box-company .info .siteName { margin-bottom: 10px; text-align: left; } }
.box-company .info .siteName img { width: 320px; }
@media screen and (max-width: 480px) { .box-company .info .siteName img { width: 80%; } }
.box-company .info .companyName { font-size: 1.2em; background: url(../img/stb.jpg) no-repeat left center; background-size: 32px; padding-left: 42px; margin-bottom: 5px; }
@media screen and (max-width: 480px) { .box-company .regist { padding: 0 10px; } }
.box-company .regist .in { padding: 30px; border: 1px solid #ddd; }
@media screen and (max-width: 480px) { .box-company .regist .in { padding: 10px; font-size: 12px; } }

/*---------------------------------------
Layout
---------------------------------------*/
.layout { width: 1160px; margin: 0 auto; }
@media screen and (max-width: 480px) { .layout { width: 100% !important; } }

/*---------------------------------------
Box
---------------------------------------*/
.box-contact { text-align: center; }
.box-contact .mainLead { font-size: 1.2em; font-weight: bold; line-height: 1.5; }
.box-contact .subLead { font-size: 1.2em; font-weight: bold; margin-bottom: 15px; }
@media screen and (max-width: 480px) { .box-contact .subLead { font-style: 1em; margin-bottom: 5px; } }
.box-contact .line { margin-top: 20px; }
.box-contact .line a { background: #00B900; color: #fff; font-weight: bold; font-size: 1.2em; padding: 10px 30px; text-align: center; -webkit-border-radius: 30px; -moz-border-radius: 30px; -ms-border-radius: 30px; -o-border-radius: 30px; border-radius: 30px; }
.box-contact .line a img { height: 24px; margin-right: 20px; }
.box-contact .line a span { margin-left: 10px; font-size: 1em; }

/*---------------------------------------
Form
---------------------------------------*/
.form-keyword:after { content: ""; display: block; clear: both; }
.form-keyword label { display: none !important; }
.form-keyword .form:after { content: ""; display: block; clear: both; }
.form-keyword input[type="text"] { width: 500px; padding: 10px; line-height: 1; font-size: 1.2em; border: 1px solid #ddd; box-sizing: border-box; border-radius: 6px 0 0 6px; }
@media screen and (max-width: 480px) { .form-keyword input[type="text"] { width: 75%; } }
.form-keyword input[type="submit"] { width: 120px; padding: 12px; margin-left: -3px; line-height: 1; font-size: 1.2em; border: 1px solid #1F8CE6; box-sizing: border-box; background: #1F8CE6; color: #fff; cursor: pointer; font-family: "Font Awesome 6 Pro"; border-radius: 0 6px 6px 0; }
@media screen and (max-width: 480px) { .form-keyword input[type="submit"] { width: 20%; } }

form.mailform { background: #fff; -webkit-border-radius: 6px; -moz-border-radius: 6px; -ms-border-radius: 6px; -o-border-radius: 6px; border-radius: 6px; }
form.mailform dl dt, form.mailform dl dd { vertical-align: middle; text-align: left; }
form.mailform dl dt { margin-bottom: 20px; clear: both; font-weight: bold; position: relative; }
form.mailform dl dd { margin-bottom: 30px; }
form.mailform dl dd:after { content: ""; display: block; clear: both; }
form.mailform dl dd label { margin-right: 10px; white-space: nowrap; }
form.mailform dl dd:after { content: " "; }
form.mailform .require, form.mailform .must { background: #ff0066; color: #fff; font-size: 0.6em; padding: 1px 5px; margin-left: 10px; border-radius: 3px; }
form.mailform .example { font-size: 0.6em; padding-top: 5px; }
form.mailform .error { font-weight: bold; color: #FF0000; background: #FFF2F2; clear: both; }
form.mailform .back { padding: 20px; width: 240px; font-size: 18px; }
form.mailform input[type="text"], form.mailform textarea, form.mailform select, form.mailform input[type="number"], form.mailform input[type="email"] { width: 90%; border: 3px solid #ddd; border-radius: 6px; padding: 10px; background: #fff; }
form.mailform textarea { min-height: 200px; }

/*---------------------------------------
Button
---------------------------------------*/
.btn a, form.mailform input[type="submit"] a, form.mailform button a, .btn input, form.mailform input[type="submit"] input, form.mailform button input { padding: 15px 0; font-size: 1.2em; font-weight: bold; text-align: center; text-decoration: none !important; background: #1F8CE6; color: #fff; box-sizing: border-box; border: none; border-bottom: 2px solid #10568F; position: relative; -webkit-border-radius: 6px; -moz-border-radius: 6px; -ms-border-radius: 6px; -o-border-radius: 6px; border-radius: 6px; }
.btn a:after, form.mailform input[type="submit"] a:after, form.mailform button a:after, .btn input:after, form.mailform input[type="submit"] input:after, form.mailform button input:after { position: absolute; right: 20px; top: 50%; font-size: 12px; -webkit-transform: translateY(-50%) translateX(-50%); transform: translateY(-50%) translateX(-50%); font-family: FontAwesome; content: "\f054"; color: #fff; -webkit-transition: all 0.3s; -moz-transition: all 0.3s; -ms-transition: all 0.3s; -o-transition: all 0.3s; transition: all 0.3s; }
@media screen and (max-width: 480px) { .btn a, form.mailform input[type="submit"] a, form.mailform button a, .btn input, form.mailform input[type="submit"] input, form.mailform button input { margin: 0 10px; padding: 10px 0; } }
.btn a:hover, form.mailform input[type="submit"] a:hover, form.mailform button a:hover, .btn input:hover, form.mailform input[type="submit"] input:hover, form.mailform button input:hover { cursor: pointer; }
.btn a:hover::after, form.mailform input[type="submit"] a:hover::after, form.mailform button a:hover::after, .btn input:hover::after, form.mailform input[type="submit"] input:hover::after, form.mailform button input:hover::after { right: 10px; }
.btn.tel a, form.mailform input.tel[type="submit"] a, form.mailform button.tel a { padding: 7px 0; font-size: 1.6em; background: #fff; color: #333; border: 3px solid #1F8CE6; -webkit-box-shadow: 0 3px 0 #10568F; -moz-box-shadow: 0 3px 0 #10568F; -ms-box-shadow: 0 3px 0 #10568F; -o-box-shadow: 0 3px 0 #10568F; box-shadow: 0 3px 0 #10568F; }
.btn.tel a i, form.mailform input.tel[type="submit"] a i, form.mailform button.tel a i { color: #1F8CE6; }

.btn-gray a { padding: 10px 15px; background: #f5f5f5; border: 1px solid #ddd; -webkit-border-radius: 6px; -moz-border-radius: 6px; -ms-border-radius: 6px; -o-border-radius: 6px; border-radius: 6px; }

.btn-sexy a { padding: 10px 15px; border: 1px solid #ff0066; color: #ff0066; display: block !important; text-align: center; }

/*---------------------------------------
Elements
---------------------------------------*/
table, table.table-normal, .price-sp table, .table { width: 100%; border: solid #ddd; border-width: 1px 0 0 1px; border-collapse: collapse; border-spacing: 0; margin-bottom: 15px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box; }
table th, table td, table.table-normal th, table.table-normal td, .price-sp table th, .price-sp table td, .table th, .table td { padding: 10px; color: #333; vertical-align: top; }
table th, table .tbl_title, table.table-normal th, table.table-normal .tbl_title, .price-sp table th, .price-sp table .tbl_title, .table th, .table .tbl_title { background: #f5f5f5; text-align: left; border: #ddd solid; border-width: 0 1px 1px 1px; vertical-align: middle; }
table td, table.table-normal td, .price-sp table td, .table td { background: #fff; border: #ddd solid; border-width: 0 1px 1px 0; text-align: left; }
table a, table.table-normal a, .price-sp table a, .table a { text-decoration: underline; }

.mb0 { margin-bottom: 0; }

.mb5 { margin-bottom: 5px; }

.mb10 { margin-bottom: 10px; }

.mb15 { margin-bottom: 15px; }
@media screen and (max-width: 480px) { .mb15 { margin-bottom: 10px; } }

.mb20 { margin-bottom: 20px; }

.mb30 { margin-bottom: 30px; }
@media screen and (max-width: 480px) { .mb30 { margin-bottom: 15px; } }

.mb50 { margin-bottom: 50px; }

.mb60 { margin-bottom: 60px; }

.mt10 { margin-top: 10px; }

.mt20 { margin-top: 20px; }

.mt30 { margin-top: 30px; }
@media screen and (max-width: 480px) { .mt30 { margin-top: 15px; } }

/*---------------------------------------
ul.list { margin-bottom:30px !important; li { position: relative; margin-bottom: 10px; padding-left:30px; &:after { position: absolute; left: 0px;top:0px; content: '\f00c'; font-family: $font-icon; } }
}

ol { list-style: decimal; margin-bottom:30px; li { margin-left: 20px; padding-left: 10px; a { display: block !important; } }
}
---------------------------------------*/
/*---------------------------------------
Mobile
---------------------------------------*/
.switch { text-align: center; display: none; padding: 10px; }
.switch:after { content: ""; display: block; clear: both; }
.switch li { width: 50%; float: left; }
.switch li a { border: 1px solid #666; text-align: center; padding: 10px 0; }
.switch li a.active { background: #666; color: #fff; }

.sp-show { display: none; }
@media screen and (max-width: 480px) { .sp-show { display: block; } }

@media screen and (max-width: 480px) { .sp-hide { display: none !important; } }
.hide, .hidden { display: none; }

/*---------------------------------------
Common Style
---------------------------------------*/
.list-place li { display: inline-block; }
.list-place li a { position: relative; padding-right: 15px; }
@media screen and (max-width: 480px) { .list-place li a { font-size: 0.8em; } }
.list-place li a:after { position: absolute; right: 3px; top: 0px; content: '\f105'; font-family: "Font Awesome 6 Pro"; }

ul.list-plan { border-top: 1px solid #ddd; }
ul.list-plan li { border-bottom: 1px solid #ddd; }
ul.list-plan li a { position: relative; padding: 10px; }
@media screen and (max-width: 480px) { ul.list-plan li a { padding: 5px 10px; } }
ul.list-plan li a:after { content: ""; display: block; clear: both; }
ul.list-plan li a:hover { background: #f5f5f5; }
ul.list-plan li a > * { float: left; }
ul.list-plan li a .name { font-weight: bold; width: 600px; }
@media screen and (max-width: 480px) { ul.list-plan li a .name { width: auto; display: inline-block; } }
ul.list-plan li a .name .type { width: 80px; margin-right: 15px; font-size: 1em; color: #fff; text-align: center; display: inline-block; -webkit-border-radius: 30px; -moz-border-radius: 30px; -ms-border-radius: 30px; -o-border-radius: 30px; border-radius: 30px; }
@media screen and (max-width: 480px) { ul.list-plan li a .name .type { width: 50px; padding: 2px 0; margin-right: 0px; font-size: 10px; } }
ul.list-plan li a .name .type-pink { background: #ff0066; }
ul.list-plan li a .name .type-normal { background: #0099FF; }
ul.list-plan li a .name .type-cos, ul.list-plan li a .name .type-soft { background: #FF9900; }
ul.list-plan li a .profile { width: 420px; }
@media screen and (max-width: 480px) { ul.list-plan li a .profile { display: none; } }
ul.list-plan li a .minPrice { width: 120px; color: #ff0066; text-align: right; }
@media screen and (max-width: 480px) { ul.list-plan li a .minPrice { display: none; } }
ul.list-plan li a .minPrice span { font-weight: bold; }
ul.list-plan li a .minPrice-sp { display: none; }
@media screen and (max-width: 480px) { ul.list-plan li a .minPrice-sp { display: inline-block; color: #ff0066; text-align: right; padding-left: 5px; } }

ul.list-arrow { border-top: 1px solid #ddd; }
ul.list-arrow li a { padding: 10px 15px; border-bottom: 1px solid #ddd; position: relative; }
@media screen and (max-width: 480px) { ul.list-arrow li a { font-size: 1.2em; } }
ul.list-arrow li a:before { position: absolute; right: 15px; content: '\f105'; font-family: "Font Awesome 6 Pro"; color: #333; }

ul.list-icon:after { content: ""; display: block; clear: both; }
ul.list-icon li { line-height: 1; float: left; margin-right: 5px; }

/*---------------------------------------
search
---------------------------------------*/
.page-control { margin-bottom: 15px; }
.page-control:after { content: ""; display: block; clear: both; }
@media screen and (max-width: 480px) { .page-control { padding: 0 10px; margin-bottom: 10px; } }
.page-control .page-count { float: left; }
@media screen and (max-width: 480px) { .page-control .page-count { float: none; margin-bottom: 10px; } }
.page-control .page-count span, .page-control .page-count strong { font-size: 1.2em; font-weight: bold; }
.page-control .pager { float: right; }
@media screen and (max-width: 480px) { .page-control .pager { float: none; } }
.page-control .pager li { display: inline-block; margin-left: 5px; color: #ccc; }
.page-control .pager li.current { background: #f5f5f5; padding: 5px 10px; border: 1px solid #ddd; box-sizing: border-box; }
@media screen and (max-width: 480px) { .page-control .pager li { margin-left: 0; } }
.page-control .pager li a { background: #1F8CE6; color: #fff; padding: 5px 10px; }
@media screen and (max-width: 480px) { .page-control .pager li a { padding: 5px 10px; } }

@media screen and (max-width: 480px) { .h2, .h3, .h4 { margin: 0 10px; } }

.h2 { font-size: 2em; border-bottom: 3px solid #ddd; position: relative; display: block; margin-bottom: 30px; }
@media screen and (max-width: 480px) { .h2 { font-size: 1.6em; margin-bottom: 15px; } }
.h2 span { display: inline-block; }
.h2 span:after { display: block; bottom: -3px; left: 0; height: 3px; position: relative; background: #ff0066; content: ""; }
.h2 .in-link { float: right; }
.h2 .in-link a { font-size: 18px; padding: 5px 10px; background: #fff; border: 1px solid #333; }

.h3 { font-size: 1.6em; padding-bottom: 10px; margin-bottom: 15px; border-bottom: 1px solid #ff0066; }
@media screen and (max-width: 480px) { .h3 { font-size: 1.2em; margin-bottom: 0px; padding-bottom: 0px; } }

.h4 { border-left: 3px solid #ff0066; padding-left: 10px; margin-bottom: 15px; font-size: 1.2em; }
@media screen and (max-width: 480px) { .h4 { margin-bottom: 10px; } }

.list-topic { overflow: hidden; margin-bottom: 10px; }
@media screen and (max-width: 480px) { .list-topic { background: #fff; margin-bottom: 0; } }
.list-topic li { float: left; width: 50%; }
@media screen and (max-width: 480px) { .list-topic li { overflow: hidden; float: none; width: 100%; }
  .list-topic li:first-child { border-top: 1px solid #ddd; } }
.list-topic li a { margin-bottom: 10px; overflow: hidden; }
@media screen and (max-width: 480px) { .list-topic li a { margin-bottom: 0px; padding: 10px 10px; border-bottom: 1px solid #ddd; } }
.list-topic li a .pic { display: block; overflow: hidden; width: 100px; height: 60px; float: left; padding-right: 10px; }
@media screen and (max-width: 480px) { .list-topic li a .pic { height: 50px; } }
.list-topic li a .pic img { margin-top: -10px; }
.list-topic li a .content { width: calc(100% - 110px); float: left; }
.list-topic li a .content .title { font-size: 16px; margin-bottom: 10px; }
@media screen and (max-width: 480px) { .list-topic li a .content .title { font-size: 1em; margin-bottom: 5px; } }
.list-topic li a .content .area, .list-topic li a .content .icon { font-size: 12px; display: inline-block; }
.list-topic li a .content .area { color: #1F8CE6; }
.list-topic li a .content .icon { font-size: 11.5px; padding: 0 3px; border-radius: 10px; background: #ff0066; color: #fff; }
.list-topic li a .content .icon.hot { background: red; }

.list-update { margin-bottom: 10px; }
@media screen and (max-width: 480px) { .list-update { margin-bottom: 5px; } }
.list-update li a { font-size: 14px; overflow: hidden; padding: 5px 0; }
@media screen and (max-width: 480px) { .list-update li a { font-size: 11px; padding: 5px 10px; } }
.list-update li a .date { float: left; width: 75px; margin-right: 10px; }
@media screen and (max-width: 480px) { .list-update li a .date { width: 60px; } }
.list-update li a .content { float: left; width: calc(100% - 85px); }
@media screen and (max-width: 480px) { .list-update li a .content { width: calc(100% - 70px); } }
.list-update details .details-title { text-align: right; font-size: 12px; padding-right: 10px; }
.list-update details .details-title:hover { cursor: pointer; }

/*# sourceMappingURL=screen.css.map */
