@import "fonts.css";

@charset "UTF-8";

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */

html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers.
 */

body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */

main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */

a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */

img {
  border-style: none;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */

textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */

details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Misc
   ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */

template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */

[hidden] {
  display: none;
}

ul{
  padding: 0;
}

@charset "UTF-8";

/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
/* リセットCSS ---------------------*/
html, body, div, span, iframe,
h1, h2, h3, h4, h5, h6, p, img, center,
dl, dt, dd, ol, ul, li,form, label,
table, caption, tbody, tfoot, thead, tr, th, td,
footer, header,menu, nav, section, input{
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
/*article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
    display: block;
}*/

table {
	border-collapse: collapse;
	border-spacing: 0;
}

html, body, div, span, iframe,
h1, h2, h3, h4, h5, h6, p, img, center,
dl, dt, dd, ol, ul, li,form, label,
table, caption, tbody, tfoot, thead, tr, th, td,
footer, header,menu, nav, section, input {
	/* font-family:
		"メイリオ", Meiryo,
		"ヒラギノ角ゴ Pro W3",
		"HIragino Kaku Gothic Pro W3",
		"HIragino Kaku Gothic Pro",
		Osaka,
		"ＭＳ Ｐゴシック", "MS P Gothic",
		sans-serif; */
	font-family: 'Avenir',
	'Helvetica Neue',
	'Helvetica',
	'Arial',
	'Hiragino Sans',
	'ヒラギノ角ゴシック',
	YuGothic,
	'Yu Gothic',
	'メイリオ',
	Meiryo,
	'ＭＳ Ｐゴシック',
	'MS PGothic'
}

select{
	background-color:white;
}

* {
	box-sizing: border-box;
}

/* ここまでリセットCSS ---------------------*/

/* モーダル表示時、背景のスクロール防止 */
body.fixed {
    overflow:hidden;
}

/* html{
	height: 100vh;
} */

body {
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* 画面全体の高さを確保 */
    margin: 0;
    text-align: center;
    background-color: white;
}

form {
    display: flex;
    flex-direction: column;
    flex: 1;           /* フォーム自体を画面いっぱいに広げる */
    /* padding-bottom: 100px;  ← 削除 */
    /* position: relative;    ← 削除 */
}

label.Anchor{
	text-decoration:underline;
	color:#0000ff;
}

/* ログインボタン */
input.Login {
	border: 0px;
	width: 170px;
	height: 45px;
	background-color:#add8e6;
	color:#738f99;
	cursor:pointer;
	border-radius:2px;
}

.DisplayMethod{
	justify-content: space-between;
	text-align: center;
}
.DisplayMethodBetween{
	width: 30%;
	text-align: center;
}
.DisplayMethodRight{
	width: 90%;
	text-align: right;
}
.loginWrapper{
	padding:20px 0px 30px;
}

.loginWrapper *{
	margin:0 auto;
}

.loginContainer{
	max-width:500px;
}

.loginContainer:not(.LoginId),
.loginContainer:not(.Pass){
  color:#738f99;
}
.loginMessage {
	margin:auto;
	max-width:260px;
    color:#738f99;
	text-align: center;
	font-size : 12px;
}

.loginForm{
	margin:40px 0px 30px;
}

.idForm{
	/*width:350px;*/
	margin-bottom:20px;
}

.idForm label,.passForm label{
	/*width:150px;*/
	/*display:inline-block;*/
	text-align:left;
	float:left;
	line-height: 35px
}

.idForm p,.passForm p{
	text-align:right;
	font-size:13px;
	max-width:320px;
	clear:both;
}

.idForm div,.passForm div{
	max-width:320px;
	height:35px;
}

.LoginId {
	max-width:170px;
	height:100%;
	border:1px solid #738f99;
	border-radius:2px;
	/*-ms-border:3px inset;*/
	ime-mode: disabled;
	float:right;
	/*box-shadow:4px 8px 1px 1px gray,2px 5px 3px 6px gray inset;*/
}

.Pass{
	max-width:170px;
	height:100%;
	border:1px solid #738f99;
	border-radius:2px;
	/*-ms-border:3px inset;*/
	float:right;
}

.error-red{
	padding-top:10px;
	color:red;
	font-size:17px;
}

input.Home {
	width: 75px;
	height: 35px;
	/* background: url(../img/cbtn_home.gif) left top no-repeat; */
	cursor:pointer;
	background-color: #add8e6;
    color: #738f99;
    border-radius: 2px;
}

input.InsertCart {
	width: 60px;
	height: 35px;
	/* background: url(../img/btn_cart_in.gif) left top no-repeat; */
	background-color:#add8e6;
	border-radius: 2px;
    cursor: pointer;
    font-size: 12px;
    color:#7288a3;
}

input.CheckCartButton {
	text-align:center;
	width: 150px;
	height: 35px;
	background-color: #add8e6;
	border-radius: 2px;
	cursor:pointer;
	font-size: 12px;
	border top: 0;
	padding-bottom: 0;
}

input.FileDownload {
	width: 180px;
	height: 30px;
	background: url(../img/dl.gif) left top no-repeat;
	cursor:pointer;
}

input.OrderInput {
	width: 180px;
	height: 45px;
	cursor:pointer;
	background-color:#add8e6;
	border-radius:2px;
	font-size:15px;
	color:#738f99;
}

input.OrderConfirm {
	border: 0px;
	width: 180px;
	height: 30px;
	background: url(../img/btn_confirm.gif) left top no-repeat;
	cursor:pointer;
}

input.OrderSubmit {
	width: 180px;
	height: 45px;
	/* background: url(../img/btn_submit.gif) left top no-repeat; */
	cursor:pointer;
	font-size: 15px;
    background-color: #add8e6;
    border-radius: 2px;
    color: #738f99;
}

input.AddPanel {
	border: 0px;
	width: 75px;
	height: 15px;
	background: url(../img/panel_plus.gif) left top no-repeat;
	cursor:pointer;
}

input.AddOriginal {
	border: 0px;
	width: 85px;
	height: 15px;
	background: url(../img/Original_plus.gif) left top no-repeat;
	cursor:pointer;
}

input.Delete {
	cursor: pointer;
    background-color: white;
/*     height: 100%; */
/* ↑2020/9/9 check_cartの×ボタン含むdiv要素が縦表示になるためコメント */
    width: 35px;
    padding: 0 5px;
    font-size: 30px;
}

input.Delete2 {
	/* width:  55px;
	height: 40px; */
/* 	background: url(../img/delete2.gif) left top no-repeat; */
	cursor:pointer;
	background-color:white;
	height:100%;
	width:35px;
	padding:0 5px;
	font-size:30px;
}

input.Details {
	width: 70px;
	height: 35px;
	cursor:pointer;
	font-size:12px;
	background-color:white;
	border:solid 1px #738f99;
	color:#738f99;
	border-radius: 2px;
}

input.detail-min{
	width: 55px;
}

.OriginalDetail .OriginalBtn{
	cursor:pointer;
	width: 70px;
	height: 35px;
	border-radius: 2px;
	background-color: #add8e6;
	color: #566a83;
	font-size:12px;
}

input.ShotbookSave {
	border: 0px;
	width: 150px;
	height: 20px;
	background: url(../img/shotbook_save.gif) left top no-repeat;
	cursor:pointer;
}

input.ShotbookOpen {
	border: 0px;
	width: 150px;
	height: 20px;
	background: url(../img/shotbook_open.gif) left top no-repeat;
	cursor:pointer;
}

input.Shuffle {
	width:  150px;
	height: 30px;
	/* background: url(../img/shuffle.gif) left top no-repeat; */
	cursor:pointer;
	background-color: #add8e6;
    border-radius: 2px;
    font-size: 12px;
    text-align: center;
    color: #738f99;
}

input.Shuffle2 {
	width: 110px;
	height: 30px;
	/* background: url(../img/shuffle2.gif) left top no-repeat; */
	cursor:pointer;
	background-color: #add8e6;
    border-radius: 2px;
    font-size: 12px;
    text-align: center;
    color: #738f99;
}

input.ShotEdit {
	width: 110px;
	height: 30px;
	/* background: url(../img/shot_edit.gif) left top no-repeat; */
	cursor:pointer;
	background-color: #add8e6;
    border-radius: 2px;
    font-size: 12px;
    text-align: center;
    color: #738f99;
}

input.ThumbSubmit {
	border: 0px;
	cursor:pointer;
}
.input-right{
	text-align:right;
	margin-top:20px;
}

.pageDetail .Next {
	width: 16px;
	height: 16px;
	background: url(../images/right_arrow_small.png) left top no-repeat;
	cursor:pointer;
	/* position: absolute;
	top:0;
	right:0; */
}

.modal-content .Next {
	width: 32px;
	height: 32px;
	background: url(../images/right_arrow.png) left top no-repeat;
	cursor:pointer;
	/* position: absolute;
	top:0;
	right:0; */
}

.pageDetail .Prev {
	width: 16px;
	height: 16px;
	background: url(../images/left_arrow_small.png) left top no-repeat;
	cursor:pointer;
	/* display:none; */
	/* position: absolute;
	top:0;
	left:0; */
}

.modal-content .Prev {
	width: 32px;
	height: 32px;
	background: url(../images/left_arrow.png) left top no-repeat;
	cursor:pointer;
	/* display:none; */
	/* position: absolute;
	top:0;
	left:0; */
}

input.Back {
	width: 30px;
	height: 30px;
	/* background: url(../img/btn_back.gif) left top no-repeat;
	background: url(../img/btn_back_H30.gif) left top no-repeat; */
	cursor:pointer;
	display: inline-block;
    background-color: #050F62;
    border-radius: 50%;
    font-size: 17px;
    color: white;
    line-height: 30px;
    font-weight:bold;
}

input.PhotoDisp {
	border: 0px;
	width: 1024px;
	height: 768px;
	background: url(../create_image.php) left top no-repeat;
	cursor:pointer;
}

input.BackToThumbList {
	border: 0px;
	width: 150px;
	height: 30px;
	background: url(../img/btn_return.gif) left top no-repeat;
	cursor:pointer;
}

input.ClearCart {
	width: 130px;
	height: 35px;
	/* background: url(../img/btn_check_empty.gif) left top no-repeat; */
	cursor:pointer;
/* 	float:right; */
	background-color:#8497b0;
	border-radius: 2px;
	color:white;
	font-size:12px;
}

input.BackToSizeList {
	border: 0px;
	width: 180px;
	height: 30px;
	/* background: url(../img/btn_size.gif) left top no-repeat; */
	cursor:pointer;
}

input.Cancel {
	border: 0px;
	width: 110px;
	height: 30px;
	background: url(../img/panel_cancel.gif) left top no-repeat;
	cursor:pointer;
}

input.OriginalPhoto {
	width: 150px;
	height: 35px;
	/* background: url(../img/btn_origin.gif) left top no-repeat; */
	cursor:pointer;
	background-color: #add8e6;
    border-radius: 2px;
    font-size: 12px;
    color: #738f99;
}

.mybookBtn:not(:last-child) {
	margin-bottom:10px;
}

input.PanelSubmit {
	width: 120px;
	height: 30px;
	/* background: url(../img/panel_submit.gif) left top no-repeat; */
	cursor:pointer;
	background-color: #add8e6;
    border-radius: 2px;
    font-size: 12px;
    color: #738f99;
    /* margin-bottom:20px; */
}

input.PanelClose {
	border: 0px;
	width: 120px;
	height: 30px;
	background: url(../img/panel_close.gif) left top no-repeat;
	cursor:pointer;
}

input.Upload {
	width: 120px;
	height: 35px;
	/* background: url(../img/btn_upload.gif) left top no-repeat; */
	cursor:pointer;
	background-color: #add8e6;
    border-radius: 2px;
    font-size: 15px;
    color: #738f99;
}

input.OrderChange {
	/* background: url(../img/btn_change.gif) left top no-repeat; */
	cursor:pointer;
	font-size:12px;
	background-color:#add8e6;
	border-radius: 2px;
	width: 80px;
    height: 30px;
    float:right;
    color:#738f99;
}

input.CartOrderSave {
	border: 0px;
	width: 190px;
	height: 20px;
	background: url(../img/cart_order_save.gif) left top no-repeat;
	cursor:pointer;
}

input.CartOrderOpen {
	border: 0px;
	width: 190px;
	height: 20px;
	background: url(../img/cart_order_open.gif) left top no-repeat;
	cursor:pointer;
}



input.Sheets {
	width: 30px;
	ime-mode: disabled;
	text-align: right;
}

.CartContainer{
	margin:0 auto;
	max-width:900px;
	margin-bottom:15px;
	padding: 0 10px 0;
}

/* .CartContainer .CheckCart{
	margin:0 auto;
} */

.CartStatus{
	width:300px;
	margin:0 auto;
	margin-bottom:10px;
}

.CartString{
	display:flex;
	justify-content: space-between;
}

.NumLogo span{
	color:#c0c0c0;
}
.one,.two,.three{
	display:inline-block;
	width:25px;
	height:25px;
	background-color: #c0c0c0;
    border-radius: 50%;
    font-size: 15px;
    color: white;
    line-height:25px;
}

.first,.second,.third{
	display:inline-block;
	font-size:9px;
	width:75px;
	color:#c0c0c0;
}

.blue-logo{
	background-color: #050F62;
}

.CartStatus .NumLogo .blue-font,.CartStatus .CartString .blue-font{
	color: #050F62;
}


.totalPrice{
	border:solid 2px #050F62;
	max-width:290px;
	padding:10px 0;
	margin:0 auto;
	margin-bottom:20px;
	color:#050F62;
}

input.SumSheets {
	width: 70px;
	text-align: center;
}

input.SumPrice {
	width: 70px;
	text-align: right;
}

input.ShotbookClick {
	border: 0px;
	width: 75px;
	height: 20px;
	background: url(../img/shotbookClick.gif) left top no-repeat;
	cursor:pointer;
}

input.ShotbookPlus {
	text-align:center;
	width: 65px;
	height: 35px;
/* 	background: url(../img/shotbookdx_plus.gif) left top no-repeat; */
	background-color: #add8e6;
	border-radius: 2px;
	cursor:pointer;
	font-size: 12px;
	color:#738f99;
}

input.selectBtn-min{
	width:50px;
}

input.PhotoDelete {
	text-align:center;
	width: 65px;
	height: 30px;
	/* background: url(../img/btn_cancel.gif) left top no-repeat; */
	background-color: #657a96;
    border-radius: 2px;
    cursor: pointer;
    font-size: 12px;
    color: white;

}

input.DialogButton {
	text-align: center;
    width: 65px;
    height: 35px;
    background-color: #add8e6;
    border-radius: 2px;
    cursor: pointer;
    font-size: 12px;
    color: #738f99;
}

input.OriginalChoice {
	width: 65px;
	height: 35px;
	/* background: url(../img/org.gif) left top no-repeat; */
	background-color: #add8e6;
    border-radius: 2px;
	cursor:pointer;
	font-size:11px;
	text-align:center;
	color:#738f99;
}

select.DispSize {
	width: 100px;
	height:26px;
}

select.PageJump {
	width: 40px;
	height:26px;
}

select.PanelList {
	max-width: 280px;
	/* font-family: monospace; */
	margin-left: 60px;
	font-size:11px;
	max-width:250px;
	/* height: 33px; */
}

select.OriginalList {
	width: 120px;
}

select.SizeInfo {

}

select.Prefecture {
	boder: none;
}

select.PrefectureErr {
	background-color: #FFA0A0;
}

select.Payment {

}

select.PaymentErr {
	background-color: #FFA0A0;
}

input.FamilyName {
	max-width: 120px;
}

input.FirstName {
	max-width: 120px;
}

input.Organization {
	max-width: 280px;
}

input.Part {
	max-width: 180px;
}

input.ZipCode1 {
	max-width: 40px;
	ime-mode: disabled;
}

input.ZipCode2 {
	max-width: 50px;
	ime-mode: disabled;
}

input.Address {
	max-width: 240px;
}

input.Tel {
	max-width: 240px;
	ime-mode: disabled;
}

input.Email {
	max-width: 240px;
	ime-mode: disabled;
}

/*2024/09/03 unet ND*/
.input-container {
	display: flex;
	align-items: center;
	width: fit-content; 
	border: 1px solid; 
	padding: 0;
	height: 30px;
	margin-bottom: 3px;
}
.input-container input {
	border: none;
	flex: 1;
	outline: none;
	box-sizing: border-box;
}
.input-container .kana-search {
	border: none;
	background-color: #ddd; 
	cursor: pointer;
	box-sizing: border-box; 
	height: 100%;
	border-left: 1px solid #ccc; 
	margin: 0;
	font-size: 10px;
	transition: background-color 0.3s ease;
	
}
.input-container .kana-search:active {
	background-color: #eee; /* クリック時に色を薄くする */
}
/*2024/07/13 unet ND*/

input.bankname {
	max-width: 200px;
}
input.branchname {
	max-width: 200px;
}
input.bankcode {
	margin-left: 10px;
	max-width: 140px;
	ime-mode: disabled;
}

input.branchcode {
	margin-left: 10px;
	max-width: 130px;
	ime-mode: disabled;
}
input.bankaccount {
	max-width: 100px;
	ime-mode: disabled;
}
input.holdername {
	max-width: 200px;
}
input.holdernamekana {
	max-width: 200px;
}
input.plannedprice {
	margin-left: 10px;
	max-width: 110px;
}


input.banknameErr {
	max-width: 200px;
	background-color: #FFA0A0;
}
input.branchnameErr {
	max-width: 200px;
	background-color: #FFA0A0;
}
input.bankcodeErr {
	margin-left: 10px;
	max-width: 140px;
	ime-mode: disabled;
	background-color: #FFA0A0;
}
input.branchcodeErr {
	margin-left: 10px;
	max-width: 130px;
	ime-mode: disabled;
	background-color: #FFA0A0;
}
input.bankaccountErr {
	max-width: 100px;
	ime-mode: disabled;
	background-color: #FFA0A0;
}
input.holdernameErr {
	max-width: 200px;
	background-color: #FFA0A0;
}
input.holdernamekanaErr {
	max-width: 200px;
	background-color: #FFA0A0;
}
input.holdernamekanaErr {
	max-width: 200px;
	background-color: #FFA0A0;
}
input.plannedpriceErr {
	max-width: 200px;
	background-color: #FFA0A0;
}
/*--------------------*/
input.FamilyNameErr {
	max-width: 120px;
	background-color: #FFA0A0;
}

input.FirstNameErr {
	max-width: 120px;
	background-color: #FFA0A0;
}

input.OrganizationErr {
	max-width: 280px;
	background-color: #FFA0A0;
}

input.ZipCode1Err {
	max-width: 30px;
	ime-mode: disabled;
	background-color: #FFA0A0;
}

input.ZipCode2Err {
	max-width: 40px;
	ime-mode: disabled;
	background-color: #FFA0A0;
}

input.AddressErr {
	max-width: 300px;
	background-color: #FFA0A0;
}

input.TelErr {
	max-width: 160px;
	ime-mode: disabled;
	background-color: #FFA0A0;
}

input.EmailErr {
	max-width: 240px;
	ime-mode: disabled;
	background-color: #FFA0A0;
}

input.Sebangou {
	width: 50px;
	ime-mode: disabled;
}

input.Shimei {
	width: 330px;
}

input.MybookInfo {

}

.mainWrapper{
	flex: 1;
}

/* .mainWrapper *{
	margin:0 auto;
} */

.MainTable {
	/* background-color: white; */
    /* max-width: 1200px; */
    margin:0 auto;
    /* padding: 0px 20px; */
}

/* .MainTable *{
	margin:0 auto;
} */

.header{
	background-color:white;
  	position: fixed;
    top: 0;
    left:0;
    width: 100%;
    letter-spacing: 1px;
    max-height: 400px;
    padding: 15px 0px 17px 0px;
}

.headerLogo{
	display:inline-block;
	float:left;
	height:50px;
	width:80%;
	text-align:left;
	padding-left:15px;
}

.headerItem{
	display:inline-block;
	float:right;
	height:50px;
	width:20%;
}

.title1{
	font-size:30px;
	color: #050F62;
	font-weight:900;
}
.title2{
	font-size:18px;
	color: #B8C5D3;
	font-weight:900;
}

.subTitle{
	clear:both;
	text-align:left;
	max-width:600px;
	padding-left:70px;
}

.backButtonArea{
	clear:both;
	text-align:left;
	max-width:600px;
	padding-left:5%;
}

.subTitle p{
	font-size:15px;
	line-height:1.4;
	color:#738f99;

}

.pageDetail{
	/* clear:both; */
	margin: 0 auto;
    max-width: 900px;
    padding-top: 12px;
}

.EventName {
	font-size: 24px;
	/* font-size: 25px; */
	font-weight: bold;
	color: #050F62;
	width:80%;
	border-bottom:solid 2px #B8C5D3;
	line-height:1.3;
	margin:0 auto;
}

.PostPeriod {
	font-size: 18px;
	/* font-weight: bold; */
	color: #050F62;
	width: 80%;
	line-height:1.3;
	margin:0 auto;
	padding: 2px 0 7px;
}

@media only screen and (max-width: 750px) {
  .EventName {
	font-size: 27px;
	/* font-size: 25px; */
	font-weight: bold;
	color: #050F62;
	width:80%;
	border-bottom:solid 2px #B8C5D3;
	line-height:1.3;
	margin:0 auto;
  }
  .PostPeriod {
	font-size: 20px;
	/* font-weight: bold; */
	color: #050F62;
	width: 80%;
	line-height:1.3;
	margin:0 auto;
	padding: 2px 0 7px;
  }
}

.footer {
    background-color:#050F62;
    /* position:absolute;  ← 削除 */
    /* bottom:0;           ← 削除 */
    width: 100%;
    padding: 8px 0px;
    margin-top: auto;   /* 念のため最下部に配置されるようにする */
}

.footer *{
	color:white;
	font-size:13px;
	line-height: 1.7;
}

.footer div,
.footer p{
	display:inline-block;
	margin:0px 7px;
}

.footer span{
	padding:0px 3px;
}

/*メニュー、カートの親要素*/
.nav-drawer{
  position: relative;
  display:inline-block;
  /*↑を指定しないと横並びにならない*/
  width:100%;
  height:100%;
}

/*チェックボックス等は非表示に*/
.nav-unshown {
  display:none;
}

/*Menu、Cartのアイコンの共通css*/
.nav-open{
	display: inline-block;
  width: 60px;
  height: 60px;
  line-height:60px;
  color:white;
  background-color:#050F62;
  box-shadow: -5px 0px 0px white;
  /*-webkit-box-shadow: -5px 0px 0px white;
  -moz-box-shadow: -5px 0px 0px white;*/
  /*z-index:10000;*/
  cursor: pointer;
}

/*Menu、Cartのアイコンの各css*/
.M{
	position: absolute;
	right: 0;
	top: -15;
        font-weight:lighter;
        font-size:40px;
}

.C{
	position: absolute;
	right: 65;
	top: -15;
        font-weight:bold;
        font-size:18px;
}

/*Menu、Cartのアイコン押下後、追加されるクラス*/
.open{
	background-color:white;
	border:solid;
	border-width:2Px 2px 0px;
	border-color:#050F62 #050F62 #ffffff;
	font-size:40px;
		color:#050F62;
}

/*閉じる用の透明カバー*/
#nav-close {
  display: none;
  position: fixed;
  z-index: 99;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: white;
  opacity: 0;
  transition: .3s ease-in-out;
}

/*中身*/
#nav-contentM {
  display: none;
  position: absolute;
  z-index: 9999;/*最前面に*/
  top: 45;
  right: 0;
  width: 252px;
  background: #fff;/*背景色*/
  border:solid 2px #050F62;
  padding:0px 3px;
  text-align: left;
}
#nav-contentC {
  display: none;
  position: absolute;
  z-index: 9999;/*最前面に*/
  top: 45;
  right: 0;
  width: 252px;
  background: #fff;/*背景色*/
  border:solid 2px #050F62;
  font-size: 12px;
}

#nav-contentC ul {
	display: flex;
    flex-wrap: wrap;
	padding: 0;
	margin: 0;
	width: 100%;
}


#nav-contentC ul li {
	padding: 4 4 0 4;
	margin: 0;
	list-style-type:none;
	width: 50%;
	line-height: 1.2;
}

.nav-hover:hover {
  background-color: #D2E6F5;
}
.nav-bottom {
	text-align: center;
	border-top: 2px solid #B8C5D3;
	margin-top:4px;
	padding:4px;
}
.nav-scroll {
  height: 100%;
  overflow-y: auto;
  min-height: 150px;
}
.scroll-prevent {
  position: fixed;
  z-index: -1;
  width: 100%;
  height: 100%;
}
.MenuLv1 {
	margin: 0;
	padding: 5 0 5 10;
	list-style: none;
}
.MenuLv2 {
	line-height: 1.9;
	margin: 0 0 0 30px;
	padding: 0;
	list-style: none;
}
.HeaderCaption{
	display:flex;
	flex-direction: column;
	align-items:center;
	width:70%;
	margin: 0 auto;
	text-align: left;
	padding-bottom: 10px;
}

input.UnwantedButton {
	width: 153px;
	height: 35px;
	cursor:pointer;
	font-size:12px;
	border-radius: 2px;
	background-color:white;
	text-align:center;
	border:solid 1px #738f99;
	color:#738f99;
	margin-bottom: 2px;
}
input.OriginalPhotoButton {
	width: 153px;
	height: 35px;
	cursor:pointer;
	font-size: 12px;
	border-radius: 2px;
	background-color: #add8e6;
	text-align:center;
	border top: 0;
	padding-bottom: 0;
}
/* ↓たぶん使わない */
/*チェックが入ったらもろもろ表示*/
#nav-inputM:checked ~ #nav-closeM,
#nav-inputC:checked ~ #nav-closeC{
  display: block;/*透明カバーを表示*/
  opacity: 0.0;
}

table.LoginTable {
	width: 500px;
	border-width: 4px 4px 4px 4px;
	border-style: outset;
	background-color: #8C4613;

}

.ListTable {
	max-width: 800px;
	/* max-width: 750px; */
	/* padding:20px 0px 0px 0px; */
	padding: 0 10px;
	margin-bottom: 50px;
	margin:0 auto;
}

.ListTableRow{
	display: flex;
	margin:0px 0px 10px;
	align-items:center;
}

/* ListTableRowの右側の要素 */
.InfoTable {
	display:inline-block;
	/* width:60%; */
	width:50%;
	text-align: left;
	/* padding: 60px 20px 10px 0px; */
	padding: 0 20px 0 0;
}

.ListCaption{
	padding:0px 0px 20px;
	font-size: 21px;
	line-height: 1.3;
}
.ListDetail{
	padding:0px 0px 0px 10px;
	color:#738f99;
	font-size:20px;
	line-height: 1.3;
}
.ListDetail p{
	/* font-size:18px; */
	/* line-height: 1.3; */
}

/* ListTableRowの左側の要素 */
.ListPhoto{
	/* width:40%; */
	width:50%;
}

/* 左側の要素の中の画像 */
.list-width-long{
	width:100%;
}

.list-height-long{
	width: 60%;
	height:auto;
}

.CartCaption{
	margin-bottom:10px;
}

.CapLeft{
	text-align:left;
	margin-bottom: 10px;
	font-size:17px;
	color: #738f99;
	line-height: 1.5;
}

.CapLeft span{
	line-height: 1.4;
}

.InputRight{
	text-align:right;
}

div .CheckCart {
	/* width: 100%; */
/* 	border-width: 1px 1px 1px 1px; */
/* 	border-style: solid; */
/* 	border-color: black; */
border-top:solid 2px #B8C5D3;
padding-bottom:5px;
}

.CartNum{
	width:100%;
	height:35px;
}

.CartNum .label-left {
	float:left;
	line-height:35px;
	/* display:inline-block; */
}

.CartNum .label-left span{
	padding-left:5px;
}

.CartNumRight .label-right {
	line-height:35px;
}

.CartNumRight{
	float:right;
/* 	height:100%; */
/* ↑2020/9/9 check_cartの×ボタン含むdiv要素が縦表示になるためコメント */
}

.CartNumRight *{
	vertical-align: middle;
}

.CartMain{
	display:flex;
	width: 100%;
	padding-bottom: 5px;
}

.CartPicCaption{
	text-align: left;
    line-height: 1.4;
    margin: 10px 0 10px;
    font-size: 14px;
}

.CartPic{
	width:30%;
}

.CartPic img{
	width:80%;
	height:auto;
}

.CartDetail{
	/* padding-left:10px; */
	width:70%;
	font-size:15px;
}

.CartDetail p{
	text-align:left;
}

.CartDetail p label{
	display:inline-block;
	width:55px;
}

.checkTableCell{
	display:table;
}

.checkTableCell div,.checkTableCell label{
	display:table-cell;
	text-align:left;
}

.checkTableCell label{
	width:55px;
}

/* .checkTableCell span:first-of-type{
	padding-right:5px;
} */

.CartLeftPic{
	margin-top:15px;
	width:150px;
	height:120px;
}

.CartLeftPic img{
	width:80%;
	height:auto;
}

.CartLeftPic label{
	display:block;
}

.PanelPic{
	width:30%;
}

.CartDetails{
	width:70%;
}

.CartDetail .button-bottom{
	text-align:left;
	padding-top:15px;
}

.button-bottom > input:last-of-type {
	margin-left:5px;
}

.PanelDetail{
	text-align:left;
	width: 95%;
}

.PanelDetail:not(:first-of-type){
	padding-top:5px;
}

.PanelDetail div:not(.PanelPhoto){
	margin-bottom:5px;
}

.PanelDetail label{
	display:inline-block;
	font-size: 15px;
}

.PanelDetail:not(:last-child) {
    border-bottom:solid 2px #B8C5D3;
}

.CheckCart select{
	height:30px;
}

.PanelPhoto{
	margin-bottom:10px;
	display: flex;
	margin-left:60px;
}

.PanelPhoto label{
	display:inline;
	width:60px;
	font-size:12px;
	line-height:30px;
}

.PanelPhoto button{
	display:inline;
	width: 85px;
	height: 30px;
    text-align: center;
    background-color: #add8e6;
    border-radius: 2px;
    cursor: pointer;
    font-size: 12px;
    color: #738f99;
    margin-right:5px;
    border:none;
}

#panelphotodispA label,#panelphotodispB label,#panelphotodispC label,
#panelphotodispD label,#panelphotodispE label,.marupop label{
	text-align:center;
	width:100%;
	line-height: 30px;
}

#panelphotodispA,#panelphotodispB,#panelphotodispC,
#panelphotodispD,#panelphotodispE,.marupop{
	/* display:inline; */
	display:flex;
	flex-direction: column;
	margin-right:5px;
	width:80px;
	align-self: center;
}

.marupop img{
	width:100%;
	height:auto;
}

/* .PanelPhoto *{
	vertical-align: middle;
} */

.PanelCartPic{
	display: flex;
	align-self: flex-start;
}
.PanelCartPic .PanelCartPicItem{
	display: flex;
}
.PanelCartPicItem > div{
	align-self: flex-end;
}
.PanelCartPicItem > div > div > label{
	font-size: 10px;
}
.PanelCartPicItem .TempLabel{
	text-align: initial;
}
.PanelCartPicItem .TempImg{
	max-width: 50%;
}

.PanelContainer{
	max-width:900px;
	margin:0 auto;
	padding:0 10px;
}

.PanelConfirmPic{
	margin-bottom:10px;
	display: flex;
	justify-content: center;
}
.PanelConfirmPic > div{
	margin: 0 2px;
    align-self: flex-end;
}
.PanelConfirmPic > div > div > label{
	font-size: 10px;
}
.PanelConfirmPic > div > div.panelname{
	height:15px;
}

.PanelBox{
  max-width:600px;
  margin:0 auto;
  padding-bottom:20px;
}

.PanelCaption1{
	height:35px;
	margin-bottom:10px;
}
.PanelCaption1 .label-left{
	display:inline-block;
	float:left;
	font-size:16px;
	line-height:35px;
}
.PanelCaption1 .label-right{
	display:inline-block;
	float:right;
	font-size:11px;
	border:solid 1px #738f99;
	color:#738f99;
	padding:0 10px;
	border-radius: 2px;
	/* height: 35px; */
    line-height: 33px;
}

.PanelCaption2{
	display:flex;
	margin-bottom:10px;
}

.PanelCaption2 .label-left{
	text-align:left;
	width:15%;
	font-size:15px;
}

.PanelCaption2 .label-right{
	width:85%;
	text-align:left;
}

.PanelCaption2 .label-right p{
	font-size:15px;
}

.PanelConfiBottomBtn{
	max-width: 600px;
    margin: 0 auto;
}

.PanelConfiBottomBtn p{
	font-size:15px;
	text-align:left;
    margin-bottom:10px;
    line-height:1.5;
}


.OrderContainer {
	max-width: 900px;
	/* border-width: 1px 1px 1px 1px;
	border-style: solid;
	border-color: black; */
	margin:0 auto;
	margin-bottom:40px;
	/* border-top:solid 2px #B8C5D3; */
	/* padding: 0 10px; */
}

.OrderContainer li{
	text-align:left;
	list-style-position: inside;
	font-size:12px;
}

div .OrderCaption{
	text-align:left;
	padding-top:10px;
}

.OrderInputCart {
	max-width: 670px;
    background-color: white;
    margin: 0 auto;
    margin-top:5px;
    font-size:16px;
}

.memberConfirm{
	text-align:left;
}

.memberCheckBtn{
	width:180px;
	height:35px;
	cursor: pointer;
    background-color: #add8e6;
    border-radius: 2px;
    font-size: 15px;
    color: #738f99;
}

.fileContainer > *{
	font-size:12px;
}

.fileContainer > p{
	text-align:left;
	margin-bottom:7px;
	color:#738f99;
}

.fileContainer > .uploadFile{
	color:#738f99;
}

/* .uploadFile:not(.file-label){
	text-align:left;
} */

.deleteFile{
	margin-top:10px;
}

.OrderContainer .deleteFile ul{
	text-align:left;
	padding:0 5px;
}

.OrderContainer .deleteFile ul li{
	list-style-type:none;
	display:inline-block;
	padding-right:13px;
}

.deleteFile input{
	font-size:25px;
	background-color:white;
	width:30px;
	height:30px;
	vertical-align: middle;
	cursor: pointer;
}

.deleteFile span{
	display:inline-block;
	line-height:30px;
	vertical-align: middle;
}

.FlexVertical {
	display:flex;
	flex-direction: column;
}

table.CartSum {
	/* background-color: #FFE4E1; */
	margin:0 auto;
	margin-bottom:15px;
	color:#050F62;
}

.ConfirmContainer{
	padding:0 10px 0;
	max-width:750px;
	margin:0 auto;
}

.ConfirmInfo p{
	font-size:17px;
	text-align:left;
	line-height:1.5;
	color:#738f99;
}

.ConfirmBox{
	padding-top:7px;
	margin-top:7px;
	border-top:solid 2px #B8C5D3;
}

.ConfirmCaption{
	height:30px;
}

.ConfirmCaption label{
	float:left;
	line-height:30px;
	color:#050F62;
	font-weight:bold;
	font-size:16px;
}

.ConfirmDetail{
	text-align:left;
	max-width:645px;
	margin:0 auto;
	padding:5px 10px;
	font-size:14px;
}

.ConfirmBox .Orderer{
	 word-break: break-all;
}

.ConfirmBox .Payment label{
	 display:inline-block;
	 width:100px;
}

.ConfirmBox .OrderMemo{
	 padding: 0 10px;
}

.OrderCartSumRow {
	height: 30px;
	background-color: #d3d3d3;
	display:flex;
	align-items:center;
	padding:3px 0;
}

.OrderCartLabel{
	/* font-size: 16px; */
    width: 30%;
    text-align:right;
}

.OrderCartNumTotal{
	width: 15%;
}

.OrderCartTotal{
	width: 28%;
	text-align:right;
	justify-content: right;
	font-weight:bold;
	padding-right: 3px;
}

.Blank1{
	width:15%;
}

.Blank2{
	width:33%;
}

.ConfirmBottomBtn{
  max-width:800px;
  padding:45px 10px 0;
  margin:0 auto;
}

/* .ConfirmBottomBtn::after{
  content:"";
  display:inline-block;
  width: 180px;
  height:0;
} */

.ConfirmBottomBtn .input-left{
	text-align:left;
	margin-top:20px;
}

.ConfirmBottomBtn span{
	font-size:10px;
	padding-left:7px;
	color:#050F62;
}

.ConfirmBottomBtn .input-center{

}

table.OrderCompleteTable {
	width: 400px;
	background-color: #FFF8DC;

}

table.ShuffleInfo {
	width: 200px;
	height: 100px;
	border-width: 2px 2px 2px 2px;
	border-style: solid;
	border-color: black;
	background-color: #F0F0F0;
	font-size: 15px;
}

.thumbCaption{
	text-align:left;
	max-width:560px;
}

/* thumb_list.phpのサムネが並んでる箇所の親要素 */
.thumbnailTable{
	display:flex;
	flex-wrap: wrap;
	/* max-width:900px; */
	margin:0 auto;
	padding: 10px 30px 0;
}

div.ThumbTableM {
	margin: 0 5px 8px 5px;
	width:350px;
	padding:10px;
	flex:auto;
}

div.ThumbTableS {
	margin:0 5px 10px 5px;
	width: 215px;
	padding:10px;
	flex:auto;
}

div.ThumbTableH {
	width:100%;
	margin: 0 5px 10px 5px;
	padding:5px 0;
	flex:auto;
}

div.original-h ,div.mybook-h{
	width:240px;
}

div.SelChk {
	text-align: center;
	margin:0 5px 10px 5px;
	padding:5px;
	width: 100%;
	/* border-bottom: solid 1px #a9a9a9; */
	flex:auto;
}

div.ThumbTableM .PhotoName *,
div.ThumbTableS .PhotoName *,
div.selChk *{
	display: inline;
	vertical-align: middle;
}

div.ThumbTableM .PhotoName span,
div.ThumbTableS .PhotoName span,
div.selChk span{
	padding-top: 4px;
}

.ThumbTableM .PhotoNum,
.ThumbTableS .PhotoNum,
.ThumbTableH span,
.SelChk span{
	color:#738f99;
}

/* .PhotoName .Sheets,
.SelChk .Sheets,
.ThumbTableH .Sheets{
	height:35px;
	width:40px;
	background-color:white;
} */

select.Sheets{
	height:35px;
	width:45px;
	background-color:white;
}

div.ThumbTableH *{
	display: inline-table;
	vertical-align: middle;
}

.emptiness-s{
	width: 215px;
	flex:auto;
	margin:0 5px 10px 5px;
}

.emptiness-m{
	width: 350px;
	flex:auto;
	margin: 0 5px 8px 5px;
}

.emptiness-h{
	width: 240px;
	flex:auto;
	margin: 0 5px 10px 5px;
}

.emptiness-h-original{
	width: 240px;
	flex:auto;
	margin: 0 5px 10px 5px;
}

div.OrderInput {
	max-width: 590px;
	padding-bottom: 15px;
	border-top: 2px solid #B8C5D3;
}

div.OrderCaption {
	text-align: left;
	padding: 3px;
	font-size: 16px;
	font-weight: bold;
	color: darkblue;
	/* border-top: solid 2px #B8C5D3; */
}
/*2024/06/17 unetND*/
.OrderCaption p {
	text-align: left;
	font-size: 12px;
	font-weight: lighter;
	color: red;

}

/*モーダルウィンドウの設定-------------------*/
.js-modal-open{
	cursor: pointer;
}

.modal-legacy{
    height: 100%;
    width: 100%;
    position: fixed;
	top: 0;
	left: 0;
	overflow: hidden;
	display: none;
}
.modal-bg{
	z-index: 200;
    background-color: rgba(0, 0, 0, 0.45);
    position: fixed;
    height: 120%;
    width: 100%;
    top: 0;
    left: 0;
    display:none;
}

.modal-legacy-content{
	z-index: 300;
    background: #fff;
    padding: 15px;
    position: fixed;
    width: 700px;
   	max-height: 100vh;
    border:solid 3px #003399;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%);
    display:none;
    overflow-y:auto;
}

.big-modal-content{
	 padding: 15px 15px 0;
}

.modal-parent{
	display:flex;
	flex-wrap: wrap;
	width: 100%;
    height: 100%;
}

/* 2022/07/11 追加 */
/* .batsu{
	font-size: 300%;
	font-weight: bold;
	width: 30px;
  	height: 30px;
	border: 2px solid #333; 
} */

/* .batsu {
	position: relative;
	display: inline-block;
	width: 50px;
	height: 50px;
	background: #333;
	transform: rotate(45deg);
	vertical-align: middle;
  }
  
.batsu::before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: #333;
transform: rotate(90deg);
} */

.batsu{
    display: block;
	margin:0 0 0 auto;
    width: 40px;/*枠の大きさ*/
    height: 40px;/*枠の大きさ*/
    background: #CCC;
    /* background: rgba(0, 0, 0, 0.45); */
    position: relative;
	border: 4px solid;
	z-index: 2000;
}

.batsu::before, .batsu::after{
    content: "";
    display: block;
    width: 100%;/*バツ線の長さ*/
    height: 4px;/*バツ線の太さ*/
    background: #000;
    transform: rotate(45deg);
    transform-origin:0% 50%;
    position: absolute;
    /* top: calc(14% - 5px); */
    top: calc(20% - 5px);
    left: 14%;
}

.batsu::after{
    transform: rotate(-45deg);
    transform-origin:100% 50%;
    left: auto;
    right: 14%;
}

/* .modal-parent::before{
	width:125px;
	margin:0 5px 10px;
	display:block;
	order:1;
}

.modal-parent::after{
	width:125px;
	margin:0 5px 10px;
	display:block;
} */

.modal-child{
	width:125px;
	margin:0 5px 15px;
	flex:auto;
}

.closeWrapper{
	text-align:right;
	margin-bottom:10px;
}

.closeWrapper .cross{
	font-size:30px;
	color:050F62;
	width:30px;
	background-color:white;
	font-weight:bold;
	cursor:pointer;
}

.emptiness-modal{
	width:125px;
	margin:0 5px 15px;
	flex:auto;
}

.change-btn-wrapper{
	width: 100%;
	position: relative;
}

.width-long{
	width:100%;
	height:auto;
	margin-top:5px;
	margin-bottom:5px;
}

.height-long{
	max-height:482px;
	margin-top:5px;
	margin-bottom:5px;
}

.modal-content .PhotoNum{
	position: relative;
}

.shotbook-modal .PhotoNum{
	height:32px;
}

.modal-content .PhotoName{
	position: relative;
}

.modal-content .Prev{
	position: absolute;
	top:0;
	left:0;
}

.modal-content .Next{
	position: absolute;
	top:0;
	right:0;
}



/* 並べ替えモーダル用のcss */
#sorting0{
	font-size:15px;
}

#sorting0 .caption{
	margin-top:5%;
}

#sorting0 .caption > div{
	font-size:20px;
	color:#050F62;
	border-bottom: solid 2px #B8C5D3;
	font-weight: bold;
	width:70%;
	margin:0 auto;
}

#sorting0 .caption > p:first-of-type{
	text-align:left;
	margin:0 auto;
	margin-top:15px;
	margin-bottom:5px;
	width:70%;
	line-height: 1.4;
}

#sorting0 .caption > p:last-of-type{
	text-align:left;
	width:70%;
	margin:0 auto;
	line-height: 1.4;
}

#sortable {
	cursor: pointer;
	max-height: 540px;
	width: 100%;
	margin-top:15px;
	/* display:flex; */
	/* flex:auto; */
	list-style:none;
}
#sortable li {
     float: left;
     cursor: move;
     width: 20%;
     height: 110px;
     margin-bottom: 10px;
     /* text-align: center;
	 vertical-align: middle; */
 }

.ui-state-highlight {
	height: 115px;
	width: 120px;
 }
.line-trash{
	display:flex;
	max-width:300px;
	margin:0 auto;
	margin-top:15px;
	align-items: center;
}

.line-trash div{
	flex:auto;
 }

.line-trash > div:first-of-type {
 	border:solid 1px;
 }

#trash {
	height: 64px;
	width: 64px;
	background: url(../img/gomibako.png) left top no-repeat;
	margin:0 auto;
}

#sorting0 > div:last-of-type{
	padding-top: 15px;
	margin-bottom:8%;
	clear:both;
}
 /* 前面プリント登録モーダルのcss */
 /* .print-modal{
 	padding:15px;
 } */

 .photoDetail{
 	margin:15px 0;
 }

 .print-modal p:first-of-type{
 	text-align:left;
 	font-size:15px;
 	max-width:530px;
 	margin:0 auto;
 	margin-top: 5%;
 }

 .print-modal p:last-of-type{
 	text-align:left;
 	font-size:15px;
 	max-width:420px;
 	margin:0 auto;
 	margin-bottom: 5%;
 }

 /* アップロード用のモーダルcss */
 .file-label{
	color: #738f99;
	border:solid 1px #738f99;
	/*display:inline-block;*/
	display: inline-flex;
	justify-content: center;
	align-items: center;
	height:35px;
	line-height:32px;
	width:55px;
	font-size:15px;
	cursor: pointer;
}

.file-label>input{
	display:none;
}

#fake_text_box{
	height:35px;
	border:solid 1px #738f99;
	width:300px;
	padding: 0 5px;
	margin: 15px 0;
}
 .upload-modal p:first-of-type{
 	text-align:left;
 	font-size:15px;
 	margin-top: 5%;
 }

 .upload-modal p:last-of-type{
 	text-align:left;
 	font-size:15px;
 	margin:0 auto;
 	margin-bottom: 8%;
 }

 .uploadCaption{
 	display:table;
 	width:95%;
 	margin:0 auto;
 }

 .uploadCaption > div{
 	display:table-cell;
 }

 .uploadCaption > div:nth-of-type(2){
 	text-align:left;
 }

.uploadFile{
	margin-bttom:20px;
}

.uploadBtn{
	margin-bottom:40px;
}

 .upload-modal > div:not(.uploadBtn),
 .upload-modal > p:not(:last-of-type){
 	margin-bottom:15px;
 }

 /* 文字入れ用のモーダルcss */
  #photo0{
 	font-size:15px;
 }

 #photo0 > p{
 	text-align:left;
 	width:83%;
 	margin:0 auto;
 	line-height:1.4;
 }

  #photo0 > p:first-of-type{
 	margin-top:5%
 }

 #photo0 > p:nth-of-type(2){
 	margin-bottom:5px;
 }

 #photo0 > p:last-of-type{
 	margin-top:15px;
 }

 #photo0 > div:last-of-type{
	margin:15px 0 8%;
 }

 .photo-modal-pic{
 	display:flex;
 	align-items: center;
 	margin:0 auto;
 	margin-top:15px;
 	margin-bottom:15px;
 	width:50%;
 }

 .photo-modal-pic > div{
 	width:50%;
 }

 .photo-modal-pic label{
 	display:block;
 }

 .modal-table-cell{
 	display:table;
 	width:75%;
 	margin:0 auto;
 	height:35px;
 }

 .modal-table-cell > *{
 	display:table-cell;
 	font-size:18px;
 	height:100%;
 }

 .modal-table-cell:not(:last-of-type) {
 	margin-bottom:8px;
 }

.modal-table-cell > div{
	line-height:35px;

 }
 .modal-table-cell > input{
 	width:95%;
 	display:inline-block;
 	border:solid 1px;
 	padding:0 3px;
 }

 /* 登録完了メッセージのモーダルcss */
 .okBtn{
 	text-align: center;
    width: 75px;
    height: 35px;
    background-color: #add8e6;
    border-radius: 2px;
    cursor: pointer;
    font-size: 12px;
    color: #738f99;
 }

 .modal-wrapper{
 	padding:35px 0;
 }

 .modal-wrapper > div{
 	margin-bottom:20px;
 }

 /* ショットパネルの団体～名前入力用のモーダルcss */
 .shot-modal{
 	font-size:15px;
 }

 .shot-modal > p{
 	text-align:left;
 	width:83%;
 	margin:0 auto;
 	line-height:1.4;
 }

.shot-modal > p:first-of-type{
 	margin-top:5%
 }

 .shot-modal > p:last-of-type{
 	margin-top:15px;
 }

 .shot-modal > div:first-of-type label{
	display:block;
 }

 .shot-modal > div:nth-of-type(2){
	width:80%;
	margin:auto;
 }

 .shot-modal > div:last-of-type{
	margin:15px 0 8%;
 }

.shot-table-cell{
 	display:table;
 	width:95%;
 	margin:0 auto;
 	height:35px;
 	text-align: left;
 	padding: 3px;
 }

 .shot-table-cell > *{
 	display:table-cell;
 	font-size:18px;
 	height:100%;
 }

 .shot-table-cell > div:first-of-type{
 	width:60px;
 }

 .shot-table-cell > input{
 	width:95%;
 	display:inline-block;
 	border:solid 1px;
 	padding:0 3px;
 }

 .shot-table-cell input[name="info1"]{
	height:100%;
	border:solid 1px;
 }

 .shot-table-cell input[name="info2"]{
 	height:100%;
	border:solid 1px;
 	width: 150px;
 }

 .shot-table-cell > p{
 	font-size:12px;
 }

/* pdf用のモーダル */
.pdf-modal{
	height:80%;
}

/* 2023/12/06 */
/* order_inputの注文No入力用モーダルcss */
#orderIdModal p{
	text-align:left;
	padding: 0 7px;
}

#orderIdModal label{
	margin-right:5px;
}

#orderIdModal input[type="text"]{
	height:35px;
	border:solid 1px #738f99;
	width:270px;
	padding: 0 5px;
	margin: 5px 0 10px;
	border-radius:2px;
}

#orderIdModal input[type="button"]{
	width:120px;
}
/*ここまでモーダルウィンドウの設定-------------------*/


td.LoginTd {
	text-align: center;
	background-color: #FFF8DC;
}


td.MainTableCorner {
	background-color: #FFF8DC;
}

td.Terms {
	text-align: center;
	width: 100px;
	font-size: 12px;
}

td.Tokushou {
	text-align: center;
	width: 180px;
	font-size: 12px;
}

td.Privacy {
	text-align: center;
	width: 240px;
	font-size: 12px;
}

/* .ListPhoto {
	text-align: center;
	width: 180px;
} */



/* .ListCaption {
	height: 50px;
	font-size: 20px;
	padding: 0px;
} */

.OriginalCaption{
	font-size:15px;
	max-width:450px;
	color:#738f99;
	text-align:left;
	margin:0 auto;
	padding:0 5px;
}

div.OriginalThumbContainer {
    display: flex;
    flex-wrap: wrap;
    max-width: 900px;
    margin: 0 auto;
    padding:0 10px;
}

div.OriginalList,.emptiness-oliginalList{
    width: 210px;
    flex: auto;
    margin: 0 5px 10px 5px;
    padding: 10px 0;
}

div.MemberListInfo {
    font-size: 16px;
}

div.MemberListParagraph {
    font-size: 14px;
    color: #738f99;
    margin-left: 40px;
    text-align: left;
}

section.DownloadButton a{
    font-size: 15px;
    color: #738f99;
    text-decoration: none;
    text-align: right;
}

div.DownloadButton{
    width:180px;
    height:35px;
    cursor: pointer;
    background-color: #add8e6;
    border-radius: 2px;
    font-size: 15px;
    color: #738f99;
    text-align: center;
    padding:6px;
    margin-top:10px;
    margin-left:70%;
}

@media only screen and (max-width: 750px) {
    div.DownloadButton{
        width:180px;
        height:35px;
        cursor: pointer;
        background-color: #add8e6;
        border-radius: 2px;
        font-size: 15px;
        color: #738f99;
        text-align: center;
        padding:6px;
        margin-top:10px;
        margin-left:35%;
    }
}

/* div.OriginalChoice {
    width: 210px;
    flex: auto;
    margin: 0 5px 15px 5px;
    padding: 10px 0;
} */

.OriginalPic img{
	height:100px;
	width:auto;
	cursor: pointer;
}

.OriginalName label{
	font-size:14px;
	display:inline-block;
	margin:3px 0;
}

.OriginalSelect{
	margin-top:5px;
}

td.ListNote {
	padding: 5px
}

td.ListSize {
	width: 360px;
	padding: 2px;
}

td.ListPrice {
	width: 60px;
	text-align: right;
	padding: 2px;
}

td.ThumbM {
	text-align: center;
	width: 380px;
	height: 240px;
	padding: 0px;
}

td.ThumbS {
	text-align: center;
	width: 200px;
	height: 120px;
	padding: 0px;
}

.ThumbH {
	width:40px;
}


td.SelChk {
	text-align: left;
	height: 20px;
}

td.SelRad {
	text-align: center;
	height: 20px;
}

td.Thumb {
	text-align: center;
	padding: 10px;
}

td.PhotoName {
	text-align: center;
	/* vertical-align: top; */
	height: 40px;
}

td.CartThumb {
	text-align: center;
	vertical-align: bottom;
	padding: 10px;
	width: 160px;
}

td.CartMain {
	width: 570px;
}

td.CartLeft {
	width: 190px;
}

td.CartCenter {
	text-align: left;
	width: 450px;
}

td.CartNo {
	text-align: left;
	width: 30px;
}

td.CartButton1 {
	text-align: left;
	width: 185px;
}

td.CartButton2 {
	text-align: left;
	width: 245px;
}

td.CartRight {
	text-align: right;
	width: 120px;
}

td.OrderCaption {
	text-align: center;
	padding: 3px;
	font-size: 18px;
	font-weight: bold;
	color: darkblue;
	background-color: #FFF8DC;
	border-width: 0px 0px 1px 0px;
	border-style: solid;
	border-color: black;
}

td.OrderCaptionCenter {
	width: 340px;
	text-align: center;
	padding: 3px;
	font-size: 18px;
	font-weight: bold;
	color: darkblue;
}

td.OrderCaptionLeft {
	width: 100px;
}

td.OrderCaptionRight {
	text-align: right;
	width: 100px;
}

td.OrderName {
	text-align: left;
	width: 200px;
	padding: 3px;
	font-size: 14px;
	font-weight: bold;
	border-width: 1px 1px 0px 1px;
	border-style: solid;
	border-color: black;
}

td.OrderValue {
	text-align: left;
	width: 310px;
	padding: 3px;
	border-width: 1px 1px 0px 0px;
	border-style: solid;
	border-color: black;
}

.CartCol1{
	width:40px;
	text-align:center;
}

.CartCol2{
	width:55px;
	text-align:center;
}

.CartCol3{
	width:100px;
	text-align:left;
}

.CartCol4{
	width:20px;
	text-align:center;
}

.CartCol5{
	width:85px;
	text-align:right;
}

td.OrderPriceName {
	text-align: left;
	width: 110px;
	font-size: 14px;
	font-weight: bold;
}

td.OrderPriceValue {
	text-align: right;
	width: 90px;
}
.OrderCart{
	padding:5px 0;
}

.OrderCartDetail {
	background-color: white;
	display:flex;
	align-items: center;
}

.OrderCartDetail:not(:last-child){
	padding-bottom:5px;
}

.OrderCartListCaption {
	font-size: 16px;
	font-weight: bold;
	background-color:#d3d3d3;
	text-align:left;
	padding:3px 5px;
}

 .OrderCartPic{
	width:15%;
	text-align:center;
}

.OrderCartList {
	/* font-size: 16px; */
	width:30%;
}

.OrderCartNum{
	width:15%;
}

.multiply{
	width:3%;
}

.OrderCartPrice {
	/* font-size: 16px; */
	width:30%;
}

.OrderCartSum {
	text-align: right;
	/* font-size: 14px; */
	font-weight: bold;
	width: 28%;
    padding-right: 3px;
}

td.ThumbName {
	text-align: center;
	height: 20px;
	padding: 0px;
}

td.PanelLink {
	width: 90px;
	text-align: center;
}

span.CartDisp {
	font-size: 15px;
	line-height:35px;
}

span.Indispensable {
	font-size: 11px;
	color: red;
}

span.OrderInfo {
	font-size: 12px;
	color: #738f99;
}
/*2024/06/17 unetND */ 
.OrderInfoCaption {
	text-align: left;
	font-size: 12px;
	font-weight: lighter;
} 


span.EventShowPeriod {
	font-size: 14px;
	font-weight: bold;
	color: darkblue;
}

span.Caption {
	/* font-size: 18px; */
	/* font-weight: bold; */
	color: grey;
	/* float:left; */
}

span.TextCaption {
	font-size: 16px;
	font-weight: bold;
}

span.TextEmphasis {
	font-size: 15px;
	text-decoration: underline;
	font-weight: bold;
}

span.info {
	font-size: 15px;
}

span.backButton {
	font-size: 12px;
	color:#050F62;
}

button.PanelLink ,button.panelPhotoReset{
	width: 85px;
	height:30px;
	text-align: center;
	background-color: #add8e6;
    border-radius: 2px;
    cursor: pointer;
    font-size: 12px;
	border: none;
}

textarea.Memo {
	resize: none;
	width: 100%;
}

.Limitation{
	text-align:right;
}

textarea.MemoErr {
	resize: none;
	background-color: #FFA0A0;
}

div.selectText {
	font-family:"MS ゴシック";
}

div.OriginalDispField {
   /*height:168px;*/
   height:220px;
	width:240px;
}

div.scrollingHotSpotLeft {
   min-width:75px;
   width:10%;
   /*height:168px;*/
   height:220px;
   background-repeat:repeat;
   background-position:center center;
   position:absolute;
   z-index:200;
   left:0;
}

div.scrollingHotSpotLeftVisible {
   background-image:url(../img/arrow_left.gif);
   background-color:#fff;
   background-repeat:no-repeat;
   opacity:0.35;
   -moz-opacity:0.35;
   filter:alpha(opacity = 35);
   zoom:1;
   /*height:168px;*/
   height:220px;
}

div.scrollingHotSpotRight {
   min-width:75px;
   width:10%;
   /*height:168px;*/
   height:220px;
   background-repeat:repeat;
   background-position:center center;
   position:absolute;
   z-index:200;
   right:0;
}

div.scrollingHotSpotRightVisible {
   background-image:url(../img/arrow_right.gif);
   background-color:#fff;
   background-repeat:no-repeat;
   opacity:0.35;
   filter:alpha(opacity = 35);
   -moz-opacity:0.35;
   zoom:1;
   /*height:168px;*/
   height:220px;
}

div.scrollWrapper {
   position:relative;
   overflow:hidden;
   width:780px;
   /*height:168px;*/
   height:220px;
   white-space: nowrap;
}
div.scrollableArea {
   position:relative;
   width:780px;
   /*height:168px;*/
   height:220px;
   background-color:darksalmon;
}

div.CartSum {
	background-color: #FFE4E1;
}
div.OrderInputFrame {
	display: inline-block;
}
div.DeliveryRow {
	display: flex;
}
div.DeliveryLeft {
	font-size: 12px;
	display: inline-block;
	width:15%;
}
div.DeliveryRight {
	display: inline-block;
}
div.Delivery {
	padding-left: 30px;
	text-align: left;
}
.OrderWarn {
	font-size: 10px;
	font-weight: bold;
	padding-top: 10px;
}
.OrderInputGroup {
	display: flex;
	align-items: center;
}
.PlannedRefundPrice {
    text-align: right; 
	font-weight: bold;
}
.PlannedRefundPrice>input {
    border-width: 1px;
    border-style: solid;
    margin-top: 3px;
    padding: 3px;
    text-align: right; 
}

.OrderInputGroup>input, .PlannedRefundPrice>input {
	border-width: 1px;
	border-style: solid;
	margin-top:3px;
	padding: 3px;
	align-items: right;
}
.OrderInputGroup>select {
	border-width: 1px;
	border-style: solid;
	margin-top:3px;
	padding: 3px;
}
/*2024/09/12 */
.OrderInputVertical > input{
	border-width: 1px;
	border-style: solid;
	margin-top:3px;
	padding: 3px;
}
.AccountTypeSelector {
	display: flex;
	flex-direction: row; 
	align-items: center; 
	width: 100%;
}

.AccountTypeSelector span {
	margin-right: 10px; 
}

.AccountTypeSelector input[type="radio"] {
	margin-right: 5px; 
}

.AccountTypeSelector label {
	margin-right: 20px; 
}
.makeme {
   width:780px;
   /*height:168px;*/
   height:220px;
   position:relative;
}

.makeme * {
   position:relative;
   float:left;
   margin:0; padding:0;
}

/*3期開発 2016/03/18 */

ul.panelList {
	list-style:none;
	max-width: 450px;
	margin:0 auto;
	text-align:left;
}

ul.panelList li{
	padding:0 3px;
	margin: 5px 0;
}

/* ↓このまま置いとく */
/* ul.PanelList li span:nth-of-type(2){
	padding-left:25%;
}

ul.PanelList li span:nth-of-type(3){
	padding-left:15%;
} */

ul.OrderInfo {
	padding-left: 30px;
	font-size: 12px;
	color: #738f99;
}

td.ShinebookThumbS {
	text-align: center;
	width: 260px;
	height: 120px;
	padding: 0px;
}

input.ShinebookStorage {
	width: 190px;
	height: 35px;
	cursor:pointer;
	font-size:12px;
	background-color:white;
	border:solid 1px #738f99;
	color:#738f99;
	border-radius: 2px;
	margin-bottom: 2px;
}

.ShinebookName label{
	font-size:14px;
	display:inline-block;
	margin:3px 0;
}

input.ButtonList {
	border: 0px;
	width: 130px;
	height: 30px;
	background: url(../img/btn_list.gif) left top no-repeat;
	cursor:pointer;
}

input.ButtonContinue {
	border: 0px;
	width: 130px;
	height: 30px;
	background: url(../img/btn_cont.gif) left top no-repeat;
	cursor:pointer;
}

input.ButtonPhotoChange {
	border: 0px;
	width: 60px;
	height: 25px;
	background: url(../img/btn_photo_change.gif) center bottom no-repeat;
	cursor:pointer;
}

input.ButtonPhotoChangeTop {
	border: 0px;
	width: 60px;
	height: 25px;
	background: url(../img/btn_photo_change.gif) center top no-repeat;
	cursor:pointer;
}
input.InputConfirm {
	text-align:center;
	width: 180px;
	height: 45px;
	background-color: #add8e6;
	border-radius: 2px;
	cursor:pointer;
	font-size: 15px;
	color: #738f99;
}
span.CartDispWide {
	font-size: 15px;
	/* display: inline-block;
  	width: 150px; */
}

/* ヘルプ画面のcss */
.helpContainer{
	max-width: 800px;
	text-align:left;
	margin:0 auto;
	padding:40px 10px;
}

.helpMokuji{
	margin:0 auto;
	width:280px;
	margin-bottom:35px;
	font-size:18px;
}

.helpMokuji > div:first-of-type{
	color:#050F62;
	text-align:center;
}

.helpMokuji > div:last-of-type{
	border:solid #050F62 4px;
	padding:5px;
}

.helpMokuji ul{
	list-style-position:inside;
	padding:0 15px;
}

.helpMokuji li{
	height:35px;
}

.helpMokuji a{
	color:#474242;
}

.helpBox{
	width: 100%;
	text-align: left;
	/* margin:0 auto; */
}

.helpBox:not(:last-of-type){
	margin-bottom:50px;
}

.helpBox > div:not(:last-of-type){
	margin-bottom:15px;
}

.helpBox > div:first-of-type{
	border-bottom:solid black 1px;
	color:#050F62;
	font-size:18px;
	font-weight:600;
	padding-left: 15px;
}

.helpBox .up{
	text-align:right;
}

.helpBox .up a{
	display:inline-block;
	color:#050F62;
	pointer:cursor;
}

.helpBox .up span{
	width: 25px;
    height: 25px;
    line-height: 25px;
    display: inline-block;
    background-color: #050F62;
    border-radius: 50%;
    font-size: 17px;
    color: white;
    text-align: center;
    margin-left:10px;
}

.helpBox .main{
	color: #474242;
}

.helpBox .main > p{
	width:90%;
	margin:0 auto;
	margin-bottom:25px;
}

.helpBox .main p > img {
	vertical-align: middle
}

.helpBox .main > div.help-img{
	text-align:center;
	margin-bottom:25px;
}

.helpBox .main .mainImg{
	max-width:400px;
	height:auto;
	box-shadow: 0 0 10px gray;
}

.helpBox .main ul.img-ver-mid li img {
	vertical-align: middle
}

.helpBox .main > div.help-info{
	width:85%;
	background-color:#dedfe6;
	margin:0 auto;
	padding:15px 0;
}

.helpBox .main ul.img-ver-mid li div.ftable{
	display: flex;
	flex-wrap: wrap;
	margin-left: 5%;
}

.helpBox .main > div > div {
    width: 95%;
    margin-left: auto;
    padding-right: 5px;
}

.helpBox .main li{
	/* height:45px; */
	line-height:2.0;
}

/* ご利用規約/特定商取引法に基づく表示画面のcss */
.termsContainer{
	max-width: 800px;
	text-align:left;
	margin:0 auto;
	padding:0px 10px;
}
.termsTitle{
	width: 100%;
	text-align: left;
}

.termsTitle > div:first-of-type{
	color:#050F62;
	font-size:18px;
	font-weight:600;
	padding-left: 15px;
	padding-bottom: 15px;
}

.termsTitle .main{
	color: #474242;
}

.termsTitle .main > p{
	width:90%;
	padding-left: 15px;
	margin-bottom:25px;
}

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

.termsBox > div:first-of-type{
	color:#050F62;
	font-size:18px;
	font-weight:600;
	padding-left: 15px;
}

.termsBox .main{
	color: #474242;
}

.termsBox .main > p{
	width:90%;
	margin:0 auto;
	margin-bottom:25px;
}

.tokushouBox {
	text-align: left;
	padding-left: 15px;
    width: 90%;
    margin: 0 auto;
    padding-bottom: 20px;
    display: flex;
}

.tokushouBox > span:first-of-type{
	font-size: 15px;
    font-weight: bold;
    min-width: 150px;
    display: inline-block;
    font-weight: bold;
}

.tokushouBox > span:last-of-type{
    display: inline-table;
}

/* ------shinebook_list.phpのCSS------ */
.marupopPic{
	display:flex;
	align-items:center;
	width:135px;
	margin: 5px auto;
	margin-bottom: 5px;
	justify-content: center;
}
.marupopPic .pic{
	margin-right:5px;
}

.marupopPic label{
	display:block;
}

.marupopPic input{
	margin:auto;
}


input.ManageConfirm {
	border: 0px;
	width: 170px;
	height: 45px;
	background-color:#add8e6;
	color:#738f99;
	cursor:pointer;
	border-radius:2px;
}

input.ManageComplete {
	border: 0px;
	width: 170px;
	height: 45px;
	background-color:#add8e6;
	color:#738f99;
	cursor:pointer;
	border-radius:2px;
}

/* .CheckForm input, .ManageForm input[type="checkbox"]{ */
.CheckForm input[type="checkbox"], .ManageForm input[type="checkbox"]{
	vertical-align:middle;
	line-height: 35px;

}

/* input[type="radio"],input[type="checkbox"]{
 vertical-align:middle;
} */

input.Manage {
	/* 2023/02/09 */
	/* max-width:170px; */
	width:170px;
	/* height:100%; */
	height:35px;
	border:1px solid #738f99;
	border-radius:2px;
	ime-mode: disabled;
	/* float:right; */
	/* float:left; */
	/* padding:0 3px; */
}
input.ManageReadonly {
	width:170px;
	height:35px;
	border:1px solid #738f99;
	background-color: #c0c0c0;
	border-radius:2px;
	ime-mode: disabled;
}

input.ManageErr {
	/* max-width:170px; */
	/* 2023/11/17 administrator.phpでエラーになると入力欄の長さが短くなるのでmax-widthからwidthに変更 */
	width:170px;
	/* height:100%; */
	height:35px;
	border:1px solid #738f99;
	border-radius:2px;
	ime-mode: disabled;
	/* float:right; */
	background-color: #FFA0A0;
}
/* 2023/10/10 */
/* administrator.phpで大会名と団体名のテキスト枠を消すためのクラス */
input.nameText{
	border: none;
	width:320px;
}
/* 2023/11/14 */
input.textWidth{
	width:320px;
}
.ManageWrapper{
	padding:20px 0px 30px;
}
.ManageWrapper *{
	margin:0 auto;
}
.ManageContainer {
	/* max-width:500px; */
	max-width:700px;
}

/* 2023/01/30 */
.Manage1, .Manage2, .Manage3{
	margin-bottom: 30px;
}

.ManageForm{
	margin:20px 0px 20px;
	/* display: inline-flex; */
	/*width:350px;*/
	/* margin-bottom:20px; */
	/* max-width:320px; */
	max-width:700px;
	/* height:35px; */
	text-align: left;
}
.ManageLine {
	font-size: 27px;
	font-weight: bold;
	color: #050F62;
	width:80%;
	border-bottom:solid 2px #B8C5D3;
	line-height:1.3;
	margin:0 auto;
	
}

/* 2023/01/30 */
.ManageCheck {
	line-height: 35px;
	text-align: left;
}

/* 2023/01/30 */
.CheckForm label{
	width:220px;
	margin-right:1rem;
	/* float:left; */
	/* line-height: 35px; */
}

/* 2023/01/30 */
/* .CheckForm span{
	margin-left:1rem;
} */

/* .ManageForm{
	width:350px;
	margin-bottom:20px;
	max-width:320px;
	max-width:700px;
	height:35px;
	text-align: left;
	
} */

/* .ManageForm span{ */
.ManageForm span:not(.checkSpan){
	text-align: left;
	line-height: 35px;
	font-size: 13px;
	margin-left: 15px;
}

.ManageForm .checkSpan, .CheckForm .checkSpan{
	margin-left: 1rem;
}

.ManageForm label{
	width:200px;
	display:inline-block;
	text-align:left;
	/* float:left; */
	line-height: 35px
}

.ManageForm p{
	/* text-align:right; */
	/* font-size:13px; */
	max-width:320px;
	clear:both;
}

/* .ManageForm div{ */
	/* max-width:320px; */
	/* max-width:700px; */
	/* height:35px; */
	/* text-align: left; */
/* } */

/* 2023/01/18 */
/* 2023/07/10修正 */
/* .ManageOrder, .ManageSample, .ManageSummary1, .ManageSummary2, .ManageSummary25, .ManageSummary3{ */
.ManageOrder, .ManageSample, .ManageSummary3{
	/* display: none; */
	padding: 0 0 10px 0;
}

/* 2023/07/10追加 */
.ManageOrder, .ManageSample, .ManageSummary1, .ManageSummary2, .ManageSummary25, .ManageSummary3{
/* .ManageOrder, .ManageSample, .ManageSummary3{ */
	display: none;
	/* padding: 0 0 10px 0; */
}

/* 2023/01/23 */
/* .ManageSample{
	display: none;
} */

/* 2023/01/23 */
/* .ManageSummary{
	display: none;
} */

/* 2022/12/07 */
.winterText{
	/* font-family: ; */
	color: red;
	margin: 50px 5px 20px;
	font-size: 60px;
	font-weight: bolder;
	letter-spacing: 0.01em;

}

.text1{
	line-height: 1.2em;
	margin-bottom: 17px;
}

.text2{
	font-size: 30px;
	line-height: 1.2em;
	margin-bottom: 10px;
}

.text3{
	font-size: 25px;
}

.noManage{
	margin: 10px 0;
}

/* 2023/02/09 */
select.Delivery {
	/* width: 100%; */
	width: 360px;
	max-width: 100%;
}

/* 2024/11/16 Unet HK */
select.DeliveryErr {
	width: 360px;
	max-width: 100%;
	background-color: #FFA0A0;
}

/* 2023/02/09 */
select.Payment {
	/* width: 100%; */
	width: 360px;
	max-width: 100%;
}

/* 2023/02/20 */
input.zipcode {
	height: 35px;
	border: 1px solid #738f99;
	border-radius: 2px;
}

/* 2023/02/20 */
.ManageForm select {
	height: 35px;
	border: 1px solid #738f99;
	border-radius: 2px;
}
/*--2024/08/06 Unet ND 返金依頼フォーム銀行・支店名オートコンプリート表示用ボックス--*/
.autocomplete-options {
	border: 1px solid #ddd;
	max-height: 150px;
	margin-left: 10px;
	overflow-y: auto;
	z-index: 1000;
	background-color: white;
	display: none; /* Initially hidden */
}
.autocomplete-option {
	padding: 5px;
	cursor: pointer;
}
.autocomplete-option:hover {
	background-color: #f0f0f0;
}

/*  スマホ横
------------------------------ */
@media screen and (max-width:768px){
	.modal-legacy-content{
	    width:80%;
	    height:auto;
	}
	.height-long{
		width: 51%;
	    height: auto;
	}
	#sortable li {
    	width: 33%;
    }
    .photo-modal-pic{
    	width:100%;
    }
    .pdf-modal{
	height:80%;
	}
}

/*  479px：スマホ縦
------------------------------ */
@media screen and (max-width:479px){
	.MainTable{
		/* padding:0px 10px; */
	}
	.EventName{
	font-size:20px;
	width:100%;
	}
	.PostPeriod {
	font-size: 15px;
	width: 100%;
	}
	#logoimg{
		width:100%;
		height:auto;
	}
	/* ------header.phpのCSS------ */
	#nav-contentC,#nav-contentM{
	 width:100vw;
	}
	.header{
		padding-bottom:12px;
	}

	.headerLogo{
		padding-left:12px;
	}
	.title1{
		font-size:25px;
		line-height:1.2;
		display:block;
	}
	.title2{
		font-size:15px;
		line-height:1;
		display:block;
	}

	.subTitle{
	padding:2px 12px 0;
	}

	.subTitle p{
	font-size:12px;
	}
	.pageDetail{
		padding: 12px 10px 0px;
	}

	.HeaderCaption {
    width: 100%;
    /* padding:0 10px; */
    padding-left:10px;
    padding-right:10px;
	}

	/* ------footer.phpのCSS------ */
	.footer *{
		font-size:10px;
	}

	.footer div,
	.footer p{
		display:block;
	}

	/* ------login.phpのCSS------ */
	.loginContainer{
		width:100%;
		padding:0px 20px;
	}
	.idForm label, .passForm label{
		display:inline;
	}
	.ManageContainer{
		width:100%;
		padding:0px 20px;
	}
	.ManageForm label{
		display:inline;
	}

	/* ------wintercup.phpのCSS------ */
	/* 2022/12/08 */
	.winterText{
		margin: 80px 5px 20px;
		/* font-size: 60px; */
		font-size: 30px;
	}

	.text1{
		margin-bottom: 20px;
	}

	.text2{
		/* font-size: 30px; */
		font-size: 18px;
		font-weight: normal;
		/* line-height: 1.2em; */
	}
	
	.text3{
		/* font-size: 25px; */
		font-size: 15px;
		font-weight: normal;
	}

	/* ------size_list.phpのCSS------ */

	.InfoTable{
		/* padding: 15px 5px 0px 0px; */
		padding: 0 5px 0px 0px;
		width:50%;
	}
	.ListPhoto{
		width:50%;
	}

	.ListCaption {
		font-size: 16px;
		padding: 0px 0px 7px;
    }
    .ListDetail p{
	font-size:15px;
	}

	/* ↓たぶん使わない */
	/* .ListTableRow{
		flex-direction: column-reverse
	} */

	/* ------thumblist.phpのCSS------ */
	.thumbnailTable{
		padding-right:0;
		padding-left:0;
	}
	div.SelChk,div.ThumbTableH{
		display: block;
		width: 100%;
	}
	div.ThumbTableS,div.ThumbTableM{
		width:50%;
		margin:0;
	}
	div.ThumbTableS img{
		width:60%;
		height:auto;
	}
	div.ThumbTableM img{
		width:90%;
		height:auto;
	}
	.emptiness-s,.emptiness-m{
		width: 50%;
		margin:0;
	}
	div.SelChk{
		border-bottom-style: none;
	}
	/* .modal-legacy-content{
	    width:100%;
	    height:auto;
	} */

	.modal-legacy-content{
	    width:100%;
	    height:auto;
	    padding:15px 5px;
	}

	.big-modal-content{
	    /* width:100%; */
	    height:80%;
	    padding:15px 5px 0;
	}

	.upload-modal p{
		padding:0 10px;
	}

	/* ------original_list.phpのCSS------ */
	div.OriginalThumbContainer{
		padding:0;
	}

	div.OriginalList,.emptiness-oliginalList{
		width:50%;
		margin-right:0;
		margin-left:0;
	}

	.OriginalPic img{
		width:90%;
		height:auto;
	}

	/* ------panel_confirm.phpのCSS------ */
	.PanelCaption2 .label-left{
		width:25%;
	}

	.PanelCaption2 .label-right{
		width:75%;
	}

	.PanelCaption2 .label-right p{
		font-size:12px;
	}

	.PanelBox .PanelPhoto{
		margin-left: 50px;
	}

	ul.panelList li{
		font-size:14px;
	}

	/* ------check_cart.phpのCSS------ */
	.PanelMain{
		flex-direction: column;
	}

	.PanelPic,.CartDetails{
		width:100%;
	}
	.CartPic{
	/* width:50%; */
	}

	.CartPic img{
	width:100%;
	height: auto;
	}

	.PanelPic img{
	width:30%;
	height:auto;
	}

	.CartDetail{
		padding-left:10px;
		/* width:50%; */
	}

	.CartOriginal img{
		width:60%;
		height:auto;
	}

	.PanelDetail{
		width:100%;
	}



	.checkTableCell:first-of-type {
    	margin-bottom: 10px;
   	}
	.button-bottom >input{
		width:48%;
	}

	.button-bottom > input:last-of-type {
	margin-left:0;
}

	/* ------order_input.phpのCSS------ */
	.OrderInputVertical {
		display:flex;
		flex-direction: column;
		width: 100%;
	}

	div.OrderInput {
		padding-top: 0px;
	}
	div.OrderContainer {
		padding-top: 0px;
	    padding-bottom: 0px;
	}

	input.Organization {
		width: 100%;
		max-width: 100%;
	}

	input.Address {
		width: 100%;
		max-width: 100%;
	}

	input.Tel {
		width: 100%;
		max-width: 100%;
		ime-mode: disabled;
	}

	input.Email {
		width: 100%;
		max-width: 100%;
		ime-mode: disabled;
	}

	select.Delivery {
		/* width: 100%; */
		width: 270px;
		/* max-width: 100%; */
	}
	select.Payment {
		/* width: 100%; */
		width: 270px;
		/* max-width: 100%; */
	}
	#orderIdModal input[type="text"]{
		width:170px;
	}

	/* ------order_confirm.phpのCSS------ */
	.OrderInputCart{
		font-size:13px;
	}
	/* .OrderCartPic{
		width:20%;
	} */
	.OrderCartPic img{
		width:80%;
		height:auto;
	}

	/* ------モーダル系のCSS------ */
	#fake_text_box {
    	max-width: 50%;
	}
	.print-modal > p{
		width:95%;
	}
	#sorting0 .caption > div,
	#sorting0 .caption > p:first-of-type ,
	#sorting0 .caption > p:last-of-type{
		width:95%;
	}
	#sortable li{
		width:50%;
	}

	#photo0 > p {
    	width: 95%;
   	}
   	.modal-table-cell {
    width: 95%;
    }
    .photo-modal-pic > div:first-of-type img{
    	width:80%;
    	height:auto;
    }

    /* ------ヘルプ画面のCSS------ */
    .helpBox > div:first-of-type{
	padding-left: 0;
	}
    .helpBox .main .mainImg {
    max-width: 95%;
	}
	.helpBox .main > div:last-of-type {
    width: 100%;
	}
	.helpBox .main > div > div {
    width: 90%;
	}
	.helpBox .main ul.img-ver-mid li div.ftable{
		display: block;
		margin-left: 0%;
	}

	/* ------manage_input.phpのCSS------ */
	.ManageForm label{
		width: 190px;
	}

	div .ManageSample .ManageForm span, div .ManageSummary0 .ManageSummary1 .ManageSummary2 .ManageSummary25 .ManageSummary3{
		display:block;
		margin: 0;
		/* 2023/02/09 */
		line-height:1.7;
	}

	/* 2023/02/09 */
	/* .ManageForm div */
	input.Manage, textarea.Manage{
		width:100%;
	}

	input.ManageReadonly {
		width:100%;
	}

	/* 2023/02/09 */
	div.DeliveryLeft {
		width: 20%;
	}
}

/* 2022/12/08追加 */
/*  479px：スマホ縦
------------------------------ */
@media screen and (min-width:479px){
	.br-disp {
		display: none;
	}
}

/* wosops.blade.php の <style> 内に追加 */
/* ① フッターを最下部に固定する設定 */
body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    margin: 0;
}

main {
    flex: 1; /* これでコンテンツが少なくてもフッターが下に押し出されます */
}

/* ② ヘッダーが position: fixed の場合の余白設定 */
/* JSで計算せず、CSSで高さを決めてしまうのが最も安定します */
.header {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 1000;
    height: 60px; /* ヘッダーの固定高さを指定（実情に合わせて調整） */
    background: #fff;
}

body {
    padding-top: 60px; /* ヘッダーの高さ */
}
main {
    margin-top: 0;
    padding-top: 0;
}
/* ③ ドロワーメニュー（nav-scroll）の高さ制限 */
/* これもJSを使わず、CSSの dvh (Dynamic Viewport Height) で解決できます */
.nav-scroll {
    max-height: calc(100dvh - 80px); /* 画面の高さからヘッダー分などを引く */
    overflow-y: auto;
}
.opi-company-title {
	font-size: 28px;
	font-weight: bold;
	color: #050F62;
	margin-bottom: 1em;
}
.style4 {
	line-height: 1.0;
}
.style4 a {
	color: #0000EE;
}
.opi-title {
	font-size: 24px;
	font-weight: bold;
	color: #050F62;
	margin-bottom: 1em;
	margin-left: 160px;
	text-align: left;
}

/* ─── フォーム共通スタイル (opimail / reqmail / order) ──────────────── */

/* 入力フォームテーブル（common/design.css の .table-area 相当） */
.opi-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.opi-table th {
  padding: 5px 8px;
  border: none;
  vertical-align: middle;
  white-space: nowrap;
  text-align: left;
  font-weight: bold;
}
.opi-table td {
  padding: 5px 8px;
  border: none;
  vertical-align: middle;
  width: 100%;
  text-align: left;
}

/* 確認モーダル内テーブル（common/design.css の #table-area-01 相当） */
.opi-confirm-table {
  border: none;
  width: 90%;
  margin: 0 auto;
  max-width: 600px;
  border-collapse: collapse;
}
.opi-confirm-table th {
  padding: 28px 10px 4px 10px;
  border: none;
  width: 30%;
  vertical-align: top;
  min-width: 120px;
  border-bottom: 1px solid #d0d0d0;
  text-align: left;
  white-space: nowrap;
}
.opi-confirm-table td {
  padding: 10px 0 10px 10px;
  border: none;
  text-align: left;
  border-bottom: 1px solid #d0d0d0;
  vertical-align: top;
}

/* PDFダウンロード・ご利用案内エリア */
.opi-pdf-area {
  width: 90%;
  padding: 20px 0;
  overflow: hidden;
}
.opi-pdf-area a {
  text-decoration: none;
}
.opi-pdf-btn,
.opi-readme-btn {
  display: inline-block;
  float: right;
  width: 100px;
  height: 34px;
  line-height: 34px;
  padding: 0;
  text-align: center;
  box-sizing: border-box;
  cursor: pointer;
  font-size: 0.78em;
  font-family: inherit;
  vertical-align: middle;
  appearance: none;
  -webkit-appearance: none;
}
.opi-pdf-btn {
  background-color: #4472c4;
  color: #fff;
  border: 1px solid #4472c4;
  margin-right: 20px;
}
.opi-pdf-btn:hover {
  background-color: #002060;
  color: #fff;
}
.opi-readme-btn {
  color: #5c5c5c;
  border: 1px solid #5c5c5c;
  background: none;
}
.opi-readme-btn:hover {
  color: #002060;
}

/* 注文内容エリア（テーブル外のテキストエリア） */
.opi-order-form-area {
  width: 100%;
  text-align: left;
}
.opi-order-form {
  overflow-x: auto;
  text-align: left;
}

/* 注文内容の説明文 */
.opi-font-left {
  text-align: left;
  color: #5c5c5c;
  max-width: 90%;
  margin: 4px 0;
  font-size: 90%;
  line-height: 130%;
  font-weight: bold;
}

/* ファイルアップロードボタン */
.opi-file-upload {
  display: flex;
  align-items: center;
  gap: 10px;
}
.opi-file-upload input[type="file"] {
  visibility: hidden;
  position: absolute;
}
.opi-file-btn {
  padding: 7px;
  margin-right: 10px;
  background: #aaa;
  color: #fff;
  cursor: pointer;
  white-space: nowrap;
}
.opi-btn-delete {
  padding: 5px 12px;
  background: #c0392b;
  color: #fff;
  border: none;
  cursor: pointer;
  font-size: 0.9em;
  white-space: nowrap;
}
.opi-btn-delete:hover {
  background: #922b21;
}

@media screen and (max-width: 896px) {
  .opi-order-form-area {
    margin-left: 0;
    margin-right: 0;
  }
}

/* ボタンエリア（common/design.css の .submit-area 相当） */
.opi-btn-area {
  padding: 20px 0;
  display: flex;
  align-items: center;
  gap: 24px;
}

/* 主ボタン・送信ボタン（青）（common/design.css の #opiData / #opiNext 相当） */
.opi-btn-primary {
  padding: 10px 8px;
  width: 190px;
  height: 42px;
  color: #fff;
  background-color: #4472c4;
  border: 1px solid #4472c4;
  border-radius: 0;
  cursor: pointer;
  text-align: center;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}
.opi-btn-primary:hover {
  background-color: #002060;
  color: #fff;
}

/* サブボタン・リセット（common/design.css の #reset 相当） */
.opi-btn-secondary {
  padding: 10px 8px;
  width: 190px;
  height: 42px;
  color: #fff;
  background-color: #888;
  border: 1px solid #666;
  border-radius: 0;
  cursor: pointer;
  text-align: center;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}
.opi-btn-secondary:hover {
  background-color: #666;
  color: #fff;
}

/* opi-table 内フォームコントロール高さ・フォントサイズ統一 */
.opi-table input[type="text"],
.opi-table input[type="email"],
.opi-table input[type="tel"],
.opi-table select {
  height: 32px;
  box-sizing: border-box;
  padding: 4px 6px;
  font-size: 13px;
}
.opi-table textarea {
  font-size: 13px;
  padding: 4px 6px;
  box-sizing: border-box;
}
/* hp_order_input フォーム内の全入力欄のフォントサイズを統一（ID指定による上書きをリセット） */
#orderForm input,
#orderForm select,
#orderForm textarea {
  font-size: 13px;
}

/* モーダル内送信ボタン */
.opi-btn-send {
  display: block;
  margin: 0 auto;
}

/* 必須項目の注記 */
.opi-required-note {
  text-align: left;
  font-size: 93%;
  color: #5c5c5c;
  margin-left: 10px;
}

/* 星マーク */
.opi-star {
  color: #5c5c5c;
}

/* エラーメッセージ */
.opi-error {
  color: #ff0000;
  font-size: 90%;
  margin-top: 4px;
}

/* 補足テキスト */
.opi-note {
  color: #5c5c5c;
  font-size: 0.9rem;
  font-weight: bold;
  margin-left: 6px;
}

/* ラジオボタンコンテナ */
.opi-radio {
  margin-bottom: 8px;
}
.opi-radio label {
  cursor: pointer;
}

/* 入力フィールドのサイズ（common/design.css より移植） */
input {
  max-width: 99%;
}
#name1, #name2, #tel1, #date1, #time1, .p-1, #prefe1,
#eventno1, #teamname1, #eventname1, #zipcode1 {
  width: 93%;
  max-width: 300px;
  line-height: 24px;
  font-size: 18px;
}
#mail1, #mail2, #address1, #address2, #address3, #fax1 {
  width: 93%;
  max-width: 400px;
  line-height: 24px;
  font-size: 18px;
}
#message1 {
  display: block;
  width: 100%;
  max-width: 400px;
  line-height: 24px;
  font-size: 18px;
}
#memo1, #memo2, #memo3 {
  display: block;
  width: 100%;
  max-width: 500px;
  margin: 0;
  line-height: 22px;
  font-size: 90%;
}
#memo3 {
  font-family: "MS Gothic", "ＭＳ ゴシック", "Osaka-Mono", "Courier New", monospace;
  font-size: 0.85em;
  line-height: 1.6;
}
#place1, #name3, #orderer1, #place2 {
  width: 93%;
  max-width: 300px;
  line-height: 24px;
  font-size: 18px;
}

/* 入力フィールドの枠線（リセットCSSで消えるため明示的に設定） */
.opi-table input[type="text"],
.opi-table input[type="email"],
.opi-table input[type="tel"],
.opi-table input[type="date"],
.opi-table input[type="time"],
.opi-table input[type="number"],
.opi-table input[type="file"],
.opi-table select,
.opi-table textarea {
  border: 1px solid #aaa;
  padding: 2px 4px;
}

/* 水平線 */
.opi-hr {
  margin: 20px 0;
  border: none;
  border-top: 1px solid #ccc;
}

/* SSLメッセージ */
.opi-ssl {
  font-size: 90%;
  color: #5c5c5c;
  margin: 10px 0;
}

/* モーダルヘッダー */
.opi-modal-header {
  background-color: #4472c4;
}
.opi-modal-title {
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  margin: 0;
}

/* モーダルフッター */
.opi-modal-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* レスポンシブ対応 */
@media screen and (max-width: 700px) {
  .opi-table tr {
    display: block;
    margin: 0 auto;
  }
  .opi-table th {
    display: block;
    max-width: 300px;
    padding-bottom: 2px;
    padding-top: 16px;
  }
  .opi-table td {
    display: block;
    text-align: left;
  }
  .opi-confirm-table th {
    display: block;
    width: 100%;
    text-align: left;
    border-bottom: none;
    padding-top: 6px;
  }
  .opi-confirm-table td {
    display: block;
    width: 100%;
    padding-bottom: 10px;
  }
  .opi-title {
    margin-left: 10px;
  }
}

@media screen and (max-width: 559px) {
  .opi-btn-area {
    padding: 10px;
    padding-top: 20px;
  }
  .opi-btn-primary,
  .opi-btn-secondary {
    padding: 10px 4px;
    width: 130px;
  }
}

/* ─── 個人のデータでご注文 ────────────────────────────── */
p.indentback {
  text-indent: -1em;
  padding-left: 2em;
}

/* ─── mydata フロー共通ボタン色 (元サイトに合わせた青) ─── */
.btn-mydata-primary {
  background-color: #4472c4;
  border: 1px solid #4472c4;
  color: #fff;
  border-radius: 0 !important;
}
.btn-mydata-primary:hover {
  background-color: #002060;
  border-color: #002060;
  color: #fff;
}
.btn-mydata-secondary {
  background-color: #888;
  border: 1px solid #666;
  color: #fff;
  border-radius: 0 !important;
}
.btn-mydata-secondary:hover {
  background-color: #666;
  border-color: #555;
  color: #fff;
}
/* アップロードボタン：白文字・濃グレー */
.btn-mydata-upload {
  background-color: #555;
  border: 1px solid #444;
  color: #fff;
  border-radius: 0 !important;
}
.btn-mydata-upload:hover {
  background-color: #333;
  border-color: #333;
  color: #fff;
}
.btn-mydata-upload:disabled {
  background-color: #888;
  border-color: #777;
  color: #fff;
  opacity: 0.7;
}

/* ─── 確認画面サムネイル ────────────────────────────── */
.thumb-item {
  cursor: grab;
  width: 140px;
  text-align: center;
  border: 1px solid #ccc;
  border-radius: 4px;
  padding: 6px;
  background: #fff;
  user-select: none;
}
.thumb-item.dragging {
  opacity: 0.5;
  cursor: grabbing;
}
.thumb-item img {
  max-width: 120px;
  max-height: 90px;
  display: block;
  margin: 0 auto 4px;
}
.thumb-item .thumb-name {
  font-size: 11px;
  word-break: break-all;
}
.thumb-sortable {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  min-height: 60px;
  padding: 8px;
  background: #f8f8f8;
  border: 1px dashed #ccc;
  border-radius: 4px;
}

/* ─── hp_mydata バナー・案内ボタンエリア ─── */
.mydatalogo-area {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 12px;
}
.mydataGuide-frame {
  width: 141px;
  height: 49px;
  border: 1px solid #5c5c5c;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.mydataGuidBtn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 34px;
  background-color: #888;
  color: #fff;
  border: 1px solid #666;
  border-radius: 2px;
  font-size: 13px;
  white-space: nowrap;
  text-decoration: none;
  cursor: pointer;
  box-sizing: border-box;
}
.mydataGuidBtn:hover {
  background-color: #666;
  color: #fff;
}
.mydata-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 34px;
  background-color: #888;
  color: #fff;
  border: 1px solid #666;
  border-radius: 2px;
  font-size: 13px;
  white-space: nowrap;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  font-family: inherit;
  box-sizing: border-box;
}
.mydata-action-btn:hover {
  background-color: #666;
  color: #fff;
}
/* カート商品・レイアウト料カード */
.mydata-cart-card {
  background-color: #e8e8e8;
}
/* order/confirm スクエアセクション */
.opi-section {
  border: 1px solid #dee2e6;
  margin-bottom: 1.5rem;
}
.opi-section-head {
  background-color: #8497b0;
  color: #fff;
  font-weight: bold;
  padding: 8px 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.opi-section-body {
  padding: 0;
}
.opi-section-body table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.opi-section-body table th {
  padding: 5px 12px;
  width: 30%;
  font-weight: normal;
  white-space: nowrap;
  vertical-align: top;
}
.opi-section-body table td {
  padding: 5px 12px;
  vertical-align: top;
}
.opi-section-body table tr + tr th,
.opi-section-body table tr + tr td {
  border-top: 1px solid #f0f0f0;
}
.opi-section-body .opi-section-content {
  padding: 10px 12px;
  font-size: 13px;
}
/* 金額右寄せ（0の桁を揃える） */
.mydata-price {
  min-width: 7em;
  text-align: right;
  flex-shrink: 0;
}

/* ─── スクロールバー常時表示（レイアウトシフト防止） ─── */
html {
  overflow-y: scroll;
  scrollbar-gutter: stable;
}

/* ─── ページ全体の左右マージン ─── */
body {
  margin-left: 10vw !important;
  margin-right: 10vw !important;
}

/* ─── ハンバーガーメニュー時（lg未満）レスポンシブ対応 ─── */
@media (max-width: 991.98px) {
  body {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .app-inner {
    grid-template-columns: 1fr;
  }
  .app-main {
    grid-column: 1 / -1;
  }
}

/* ─── アプリ全体レイアウト ─── */
.app-outer {
  width: 100%;
  box-sizing: border-box;
}
.app-header {
  align-items: center;
  padding: 10px 0 10px 0;
  background: #fff;
}

/* ─── カルーセル（縦基準・横クリップ） ─── */
.opi-carousel-inner {
  height: 510px;
  overflow: hidden;
}
/* Bootstrap の active/transition 中のアイテムを flex で横中央揃え */
.opi-carousel-inner .carousel-item.active,
.opi-carousel-inner .carousel-item-next,
.opi-carousel-inner .carousel-item-prev {
  display: flex !important;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  height: 510px;
}
/* 画像は縦基準でスケール、横はみ出しOK */
.opi-carousel-inner .carousel-item img {
  height: 510px;
  width: auto;
  max-width: none;
  flex-shrink: 0;
  display: block;
}
.header-logo {
  width: 280px;
  height: auto;
}
.app-inner {
  display: grid;
  grid-template-columns: 200px 1fr;
  align-items: start;
}
.app-sidebar {
  min-height: 100vh;
  overflow: hidden;
}
.app-sidebar .main-logo {
  width: 170px !important;
}
.app-sidebar .nav-btn {
  min-width: 0 !important;
  width: 100% !important;
  margin: 0 !important;
  padding-left: 8px !important;
  padding-right: 8px !important;
  box-sizing: border-box !important;
}
.app-main {
  min-width: 0;
  padding: 0 16px;
  text-align: left;
}