/* CSSの記法はOOCSSを参考に

命名に役立ちそう
https://www.tohoho-web.com/bootstrap/buttons.html
*/

:root {
    --font-size-SS: 10px;
    --font-size-S: 14px;
    --font-size-M: 20px;
    --font-size-L: 24px;
    --font-size-O: 28px;
    
    --primary-color: #005aff;
    --primary-background-color: #ddeeff;
    --danger-color: #ff003a;
    --danger-background-color: #ffd0db;
    --warning-color: #cccc00;
    --warning-background-color: #fbfba2;
    --success-color: #55bb00;
    --success-background-color: #d4ffcd;
    --disable-color: #777777;
    --disable-background-color: #aaaaaa;

    --px-O: 20px;
    --px-L: 12px;
    --px-M: 8px;
    --px-S: 4px;
    --px-SS: 2px;
}

body {
    font-family: 'Verdana','Hiragino Sans','Meiryo',sans-serif;
}

h1 {
    font-size: 36px;
    text-align: center;
}

h2 {
    font-size: var(--font-size-O);
    text-align: center;
}
  
h3 {
    font-size: var(--font-size-O);
    text-align: left;
}

h4 {
    font-size: var(--font-size-L);
    text-align: left;
}

a {
    color: #005FFF;
    text-decoration: none;
}

table {
    font-size: var(--font-size-S);
    width: 1%;
    table-layout: fixed;
    word-wrap: break-word;
}

th {
    text-align: center;
    padding: 6px;
    border: solid 1px;
}

td {
    padding: 6px;
    border: solid 1px;
}

textarea,
input,
select {
    color: #000000;
    background-color : #eeeeee;
    border-radius: 4px;
    text-align: left;
    padding: 2px 4px;
    height: 25px;
}
::placeholder {
    color: #aaaaaa;
}
:disabled{
    background-color: var(--disable-background-color);
}

select {
    background-image: url(http://daira.icurus.jp/product/img/select_arrow_icon16x.png);
    background-position: right 10px center;
    background-repeat: no-repeat;
    background-size: 13px 13px;
    padding-right: 31px;
}

input[type="date"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button
{
    display: none;
}

input[type="date"],
input[type="datetime-local"] {
    background-image: url(http://daira.icurus.jp/product/img/date_input_icon16x.png);
    background-position: right 7px center;
    background-repeat: no-repeat;
    background-size: 15px 15px;
    padding-right: 15px;
}

input[type="time"] {
    background-image: url(http://daira.icurus.jp/product/img/time_input_icon16x.png);
    background-position: right 7px center;
    background-repeat: no-repeat;
    background-size: 15px 15px;
    padding-right: 15px;
}

input[type="date"] {
    width: 135px;
}

input[type="datetime-local"] {
    width: 195px;
}

input[type="time"] {
    width: 90px;
}

button {
    background-color: #ffffff;
    font-size: var(--font-size-L);
    padding: 2px 4px;
    border-radius: 8px;
    border: solid 1px #000000; 
    text-align: center;
    color: #000000;
}

/* div関連のCSS */
.main {
    margin: 80px 8px 108px 8px;
}

.radius-zero {
    border-radius: 0;
}

.radius-S {
    border-radius: var(--px-S);
}

.radius-M {
    border-radius: var(--px-M);
}

.radius-L {
    border-radius: var(--px-L);
}

.box-shadow-black-alpha {
    box-shadow: 1px 1px 3px #00000055;
}

/* 登録・編集ページ */
.edit-page {
    max-width: 700px;
    margin: 0 auto;
}

.flex {
    display: flex;
}

.flex-align-end {
    display: flex;
    align-items: flex-end;
}

.flex-align-center {
    display: flex;
    align-items: center;
}

.flex-wrap {
    display: flex;
    flex-wrap: wrap;
}

.display-none {
    display: none;
}

.width-auto {
    width: auto;
}

.width-100-percent {
    width: 100%;
}

.width-60-percent {
    width: 60%;
}

.width-45-percent {
    width: 45%;
}

.width-48-percent {
    width: 45%;
}

.width-10-percent {
    width: 10%;
}

.width-4-percent {
    width: 4%;
}

.width-300px {
    width: 300px;
}

.max-width-400px {
    max-width: 400px;
}

.max-width-700px {
    max-width: 700px;
}

.max-width-100-percent {
    max-width: 100%;
}

.height-100-percent {
    height: 100%;
}

.min-height-120px {
    min-height: 120px;
}

.min-height-60px {
    min-height: 60px;
}

.min-height-40px {
    min-height: 40px;
}

.relative-position {
    position: relative;
}

/* 背景CSS */
.background-normal {
    background-color: #ffffff;
}

.background-primary {
    background-color: var(--primary-background-color);
}

.background-disable {
    background-color: var(--disable-background-color);
}

.background-light-gray {
    background-color: #dddddd;
}

.background-danger {
    background-color: var(--danger-background-color);
}

.background-success {
    background-color: var(--success-background-color);
}

.background-warning {
    background-color: var(--warning-background-color);
}

/* ボーダー関連のCSS */
.border-bottom-gray {
    border-bottom: 1px solid #cccccc;
}

/* テーブル関連のCSS */
.th-primary {
    background-color: var(--primary-color);
    border-color: var(--secondary-color);
    color: #ffffff;
}

.th-transparent {
    background-color: transparent;
    color: transparent;
    border : solid 0px;
}

/* ボタン関連のCSS */
.button-primary {
    border: 0px;
    background-color: var(--primary-color);
    color: #ffffff;
}

.button-outline-primary {
    border: 1px solid var(--primary-color);
    background-color: #ffffff;
    color: var(--primary-color);
}

.button-outline-reset {
    border: 1px solid #555555;
    background-color: #ffffff;
    color: #555555;
}

.button-danger {
    border: 0px;
    background-color: var(--danger-color);
    color: #ffffff;
}

.button-large {
    font-size: var(--font-size-L);
    padding: var(--px-M);
    border-radius: var(--px-M);
}

.button-middle {
    font-size: var(--font-size-M);
    padding: var(--px-S) var(--px-M);
    border-radius: var(--px-M);
}

.button-small {
    font-size: var(--font-size-S);
    padding: var(--px-SS) var(--px-S);
    border-radius: var(--px-S);
}

/* テキスト関連のCSS */
.font-size-O {
    font-size: var(--font-size-O);
}

.font-size-L {
    font-size: var(--font-size-L);
}

.font-size-M {
    font-size: var(--font-size-M);
}

.font-size-S {
    font-size: var(--font-size-S);
}

.font-size-SS {
    font-size: var(--font-size-SS);
}

.font-normal {
    font-weight: normal;
}

.font-bold {
    font-weight: bold;
}

.font-color-black {
    color: #000000;
}

.font-color-white {
    color: #ffffff;
}

.font-color-light-gray {
    color: #aaaaaa;
}

.font-color-gray {
    color: #777777;
}

.font-color-dark-gray {
    color: #555555;
}

.font-color-notice {
    color: var(--danger-color);
}

.font-color-success {
    color: var(--success-color);
}

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

.text-align-center {
    text-align: center;
}

.text-align-left {
    text-align: left;
}

.overflow-wrap-break-word {
    overflow-wrap: break-word;
}

.white-space-nowrap {
    white-space: nowrap;
}

/* Input関連のCSS */
.input-error {
    border: solid 1px var(--danger-color);
}

/* ステータスバー関連のCSS */
.status-bar {
    width: 6px;
    margin-right: var(--px-S);
    border-radius: 3px;
}

.status-bar-disable {
    background-color: var(--disable-color);
}

.status-bar-primary {
    background-color: var(--primary-color);
}

.status-bar-safety {
    background-color: var(--success-color);
}

.status-bar-warning {
    background-color: var(--warning-color);
}

.status-bar-danger {
    background-color: var(--danger-color);
}



.flex-textarea-dummy {
    overflow: hidden;
    visibility: hidden;
    box-sizing: border-box;
    white-space: pre-wrap;
    word-wrap: break-word;
    overflow-wrap: anywhere;
}

.flex-textarea {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    overflow: hidden;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    resize: none;
}