/*
Theme Name: BlankSlate
Theme URI: https://opencollective.com/blankslate
Author: Web Guy
Author URI: https://opencollective.com/blankslate#section-contributors
Description: Donate: https://opencollective.com/blankslate. Learn: https://blankslate.me/. BlankSlate is the definitive WordPress boilerplate starter theme. I've carefully constructed the most clean and minimalist theme possible for designers and developers to use as a base to build websites for clients or to build completely custom themes from scratch. Clean, simple, unstyled, semi-minified, unformatted, and valid code, SEO-friendly, jQuery-enabled, no programmer comments, standardized and as white label as possible, and most importantly, the CSS is reset for cross-browser-compatability, with no intrusive visual CSS styles added whatsoever. A perfect skeleton theme. For support and suggestions, go to: https://github.com/webguyio/blankslate/issues. Thank you.
Tags: accessibility-ready, one-column, two-columns, custom-menu, featured-images, microformats, sticky-post, threaded-comments, translation-ready
Version: 2025
Requires at least: 5.2
Tested up to: 6.8
Requires PHP: 7.4
License: GNU General Public License v3 or Later
License URI: https://www.gnu.org/licenses/gpl.html
Text Domain: blankslate

BlankSlate WordPress Theme 2011-2025
BlankSlate is distributed under the terms of the GNU GPL
*/

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;font-size:100%;font:inherit;vertical-align:baseline}html{scroll-behavior:smooth}body{line-height:1}a{text-decoration-skip-ink:auto}a[href^="tel"]{color:inherit;text-decoration:none}button{outline:0}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}q{display:inline;font-style:italic}q:before{content:'"';font-style:normal}q:after{content:'"';font-style:normal}textarea,input[type="text"],input[type="button"],input[type="submit"],input[type="reset"],input[type="search"],input[type="password"]{-webkit-appearance:none;appearance:none;border-radius:0}input[type="search"]{-webkit-appearance:textfield}table{border-collapse:collapse;border-spacing:0}th,td{padding:2px}big{font-size:120%}small,sup,sub{font-size:80%}sup{vertical-align:super}sub{vertical-align:sub}dd{margin-left:20px}kbd,tt{font-family:courier;font-size:12px}ins{text-decoration:underline}del,strike,s{text-decoration:line-through}dt{font-weight:bold}address,cite,var{font-style:italic}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
.sticky{}.bypostauthor{}.wp-caption{}.wp-caption-text{}.gallery-caption{}.alignright{}.alignleft{}.aligncenter{}
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute!important;width:1px;word-wrap:normal!important;word-break:normal}
.screen-reader-text:focus{background-color:#f7f7f7;border-radius:3px;box-shadow:0 0 2px 2px rgba(0,0,0,.6);clip:auto!important;-webkit-clip-path:none;clip-path:none;color:#007acc;display:block;font-size:14px;font-size:.875rem;font-weight:700;height:auto;right:5px;line-height:normal;padding:15px 23px 14px;text-decoration:none;top:5px;width:auto;z-index:100000}
.skip-link{left:-9999rem;top:2.5rem;z-index:999999999;text-decoration:underline}
.skip-link:focus{display:block;left:6px;top:7px;font-size:14px;font-weight:600;text-decoration:none;line-height:normal;padding:15px 23px 14px;z-index:100000;right:auto}
.visually-hidden:not(:focus):not(:active), .form-allowed-tags:not(:focus):not(:active){position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px, 1px, 1px, 1px);white-space:nowrap}

html {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 12px;
  font-weight: 400;
  text-align: center;
  margin: 0;
  padding: 0;
  color: #FFFFFF;
}

body {
  background: url("./common/img/bg.jpg")center / cover;
  background-attachment: fixed
}

ul li {
  list-style: none;
}

ul,
li {
  margin: 0;
  padding: 0;
}

h2 {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 30px;
}

a {
  color: #FFFFFF;
  text-decoration: none;
}

.MV {
  padding: 0 !important;
  margin: 0 !important;
  font-size: 0;
  background-color: #ffffff;
}

.MV img {
  margin: 0 !important;
  width: 100%;
}

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

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

.overview {
    padding: 50px 75px;
    font-size: 15px;
	line-height: 1.8;
    font-weight: 500;
    color: #000000;
    text-align: left;
}

.award {
    background-color: #FFFFFF;
}

.award img {
    margin: 20px auto;
    padding: 20px 20px 40px 20px;
}

.award-title {
  position: relative;
  display: inline-block;
  font-size: 50px;
  font-weight: bold;
  padding-bottom: 5px;
}

.award-title {
   background: linear-gradient(90deg, 
    #00F0FF 0%, 
    #0094FF 20%, 
    #0F0FFF 45%, 
    #E100E5 80%, 
    #FF00B8 98%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.award-title::after {
  content: '';
  display: block;
  background-color: black;
  height: 5px;
  width: 75px;
  margin: 10px auto 0;
}

/* 投票方法 */

.how-to-vote {
  text-align: center;
  padding: 40px 0;
}

.vote-title {
  color: #ffffff;
　font-weight: bold;
  font-size: 40px;
  margin-bottom: 5px;
}

.vote-title::after {
  content: '';
  display: block;
  width: 75px;
  height: 5px;
  background-color: #EA2C48;
  margin: 10px auto 40px;
}

.vote-box {
  position: relative;
  background-color: #ffffff;
  border-radius: 8px;
  margin: 0 40px;
  padding: 0 25px 25px;
}

.vote-subtitle {
  background-color: #00aaff;
  color: #000000;
  font-size: 18px;
　font-weight: bold;
  padding: 15px;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  margin: 0 -25px 20px -25px;
}

.vote-text {
  color: #EA2C48;
  font-size: 25px;
  font-weight: bold;
  line-height: 1.2;
}

.vote-subtext {
  display: block;
  color: #000000;
  font-size: 18px;
  font-weight: normal;
  margin-top: 5px;
}

.vote-period,
.vote-result {
  margin-top: 25px;
  text-align: left;
}

.vote-period-button,
.vote-result-button {
  display: inline-block;
  color: #ffffff;
  padding: 4px 20px;
  border-radius: 20px;
  font-size: 16px;
  font-weight: normal;
  margin-bottom: 10px;
}

.vote-period-button {
  background-color: #D70000;
}

.vote-result-button {
  background-color: #000000;
}

.vote-period-text1 {
    color: #000000;
    font-size: 22px;
    font-weight: bold;
    margin: 0;
    line-height: 1.3;   
}

.vote-subtext span {
  color: #02A7FA;
  font-weight: bold ;
}

.vote-period-text2,
.vote-result-text {
  color: #000000;
  font-size: 26px;
  font-weight: bold;
  margin: 0;
  line-height: 1.3;
}

.character-img {
  position: absolute;
  bottom: -30px;     
  right: -40px; 
  width: 200px;
  height: auto;
  z-index: 1;  
}

.vote-annotation {
    color: #000000;
    font-size: 12px;
	line-height: 1.6;
    text-align: left;
    padding: 20px 75px 0 0;
}

/* 無断転載NG */
.prohibited {
  display: flex;
  align-items: center; 
  gap: 20px;          
  background-color: #0F2C35;
  padding: 35px;            
  margin: 0 auto;
}

.prohibited-img {
  width: 115px;
}

.prohibited p {
  margin: 0;
  color: #eaf0f6;
  font-size: 16px;
  line-height: 1.6;
  text-align: left;
}

/* 作品一覧 */

.works {
    padding: 40px 0;
}

.works .section-title {
  color: #ffffff;
  font-size: 40px;
  font-weight: bold;
  margin-top: 0;
  margin-bottom: 0;
}

.works .section-title::after {
  content: '';
  display: block;
  width: 75px;
  height: 5px;
  background-color: #FFEE00;
  margin: 15px auto 20px;
}

.works .day {
  display: block;
  text-align: center;
  background-color: #D62341;
  color: #ffffff;
  padding: 12px 0;
  margin: auto 20px;
  border-radius: 8px;
  font-size: 18px;
  font-weight: 500;
}

.works-list {
  display: grid; 
  grid-template-columns: 1fr 1fr;
  margin: 0 20px 0 0;
}

.works-list ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.works-list li{
	grid-row: span 3;
    grid-template-rows: subgrid;
    gap: 0px;
    display: grid;
	margin-bottom: 8px;
}
.works-list dl {
  padding: 20px 0 0 20px;
  border-radius: 8px;
  text-align: center;
	grid-row: span 3;
    grid-template-rows: subgrid;
    gap: 0px;
    display: grid;
}

.works-list dt img {
  border-radius: 4px;
  display: block;
}

.works-list dd.tit {
  color: #ffffff;
  font-size: 16px;
  margin: 8px 0;
  line-height:1.3;
}

.works-list .bt {
  padding: 2px; 
  border-radius: 4px;
  background: linear-gradient(90deg, 
    #00F0FF 0%, 
    #0094FF 20%, 
    #0F0FFF 45%, 
    #E100E5 80%, 
    #FF00B8 98%
  );
}

.works-list .bt a {
  display: block;
  background-color: #000000;
  color: #ffffff;
  text-decoration: none;
  font-weight: bold;
  padding: 12px 0;
    border-radius: 4px;
    font-size: 14px;
}


.how-to-vote ,
.works {
    background-color: #252525;
    margin-bottom: 0;
}

/* footer全体の基本スタイル */
footer {
  background-color: #2c304b;
  padding: 60px 40px;
}

.footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 auto; 
}

.attention {
  width: 100%;
  text-align: left;
}

.attention-title {
  color: #ffffff;
  font-size: 20px;
  font-weight: bold;
  margin: 0 0 20px 0;
  text-align: left;
}

.attention-content p {
  color: #e0e0e0;
  font-size: 14px;
  line-height: 1.8;
  margin: 0;
}

.logo {
  margin: 50px 0;
}

.logo img {
  width: 120px;
}

.footer-links {
  display: flex;
  gap: 30px;    
  margin-bottom: 15px;
}

.information a,
.contact a {
  color: #ffffff;
  font-size: 14px;
}

.footer-bottom {
  display: flex;
  align-items: center;
  gap: 15px;    
  font-size: 13px;
}

.copyright p {
  color: #ffffff;
}

.privacypolicy a {
  color: #c6c6c6;
  text-decoration: underline;
}

@media only screen and (min-width: 460px) {

  img {
    max-width: 100%;
  }

  .wrap {
    max-width: 480px;
    margin: 0 auto;
    padding: 0;
  }
}

/* --- 作品詳細ページのコンテナ --- */

body {
  margin: 0;
}

.main {
  width: 480px;
  margin: 0 auto;
}

.work-detail-page {
  margin: 0 auto;
  background: url(./common/img/haikei.png) top center / cover; 
  background-color:#ffffff; 
  background-repeat: no-repeat;
}

.work-header {
  padding-top: 20px;
  margin-bottom: 20px;
  position: relative;
  text-align: center;
  overflow: visible;
}

.back-button {
  position: absolute;
  top: 20px;
  left: 20px;
  color: #ffffff;
  text-decoration: none;
  font-weight: bold;
  font-size: 16px;
  display: flex;
  align-items: center;
}

.back-button::before {
    content: '←';
    margin-right: 5px;
}

.page-logo {
  width: 150px;

}

.work-image {
  width: 60%;
  max-width: 200px;
	height:auto;
  border-radius: 8px;
  box-shadow: 0 0 8px rgba(101, 101, 101, 0.2);
  margin-top: 0;
  margin-bottom: 10px;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.work-title {
  font-size: 22px;
  font-weight: bold;
  margin: 15px 80px;
  text-align:center;
  color: #000000;
}

.author-name {
  font-size: 16px;
  color: #000000;
  margin-top: 10px;
  margin-bottom: 25px;
}

.arasuji {
	color:#000000;
	font-size: 15px;
    margin: 25px 40px;
    text-align: left;
    line-height: 1.7;
}

.detail-button {
  display: block;
  padding: 30px;
  margin: 10px auto;
  width: 90%;
  max-width: 300px;
  border: none;
  border-radius: 100px;
  color: white;
  font-size: 18px;
  font-weight: bold;
  text-decoration: none;
  cursor: pointer;
}

.detail-button.main-vote {
  background-color: #D70000;
}

.detail-button.kindle {
  background-color: #000000;
}


/* --- 購入リンク部分 --- */
.purchase-links {
  text-align: center;
  padding: 30px 20px;
}

.purchase-title {
  color: #000000;
  margin: 0 auto 25px auto;
  font-size: 16px;
  font-weight: bold;
  position: relative;
  width: fit-content;
}

.purchase-title::before,
.purchase-title::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 50px;
  height: 2px;
  background-color: #000000;
}
.purchase-title::before {
  left: -60px;
}
.purchase-title::after {
  right: -60px;
}

.store-button {
  display: block;
  background-color: #02A7FA;
  color: white;
  text-decoration: none;
  padding: 30px;
  border-radius: 8px;
  font-size: 16px;
  font-weight: bold;
  margin: 10px auto;
  width: 90%;
  max-width: 300px;
}

/* 「投票完了」のメッセージ */
.vote-complete-message {
  display:none;
  color: #c81e39;
  font-size:18px;
  font-weight: bold;
  margin-bottom: 10px;
}

/* 「投票をシェアする」ボタンのスタイル */

.share-vote {
  display:none;
  background-color: #ffffff;
  color: #000000;
  border: 2px solid #D70000;
}

.share-vote.btn-active {
	display:block;
	
}

.kv-copyright {
	font-size: 9px;
	color: #ffffff;
	margin: 50px 10px;
	line-height: 1.6;
}



@media screen and (max-width: 480px) {
.how-to-vote, .works {
    background-color: #252525;
    margin-bottom: 0;
    overflow-x: hidden;
}
.character-img {
    bottom: -30px;
    right: -63px;
	width: 182px;
}
	.vote-period-text2 {
    color: #000000;
		font-size: 25px;align-content
	}
	.vote-result-text {
    color: #000000;
		font-size: 21px;align-content
	}
.vote-annotation {
    padding: 20px 63px 0 0;
}
}