@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Lato:400,700|Noto+Sans+JP:400,700&display=swap');

/*
 Bootstrap に合わせて Mobile first
 Extra small devices (portrait phones, less than 576px)
 No media query for `xs` since this is the default in Bootstrap
 */

/* ================ Common ================ */
.sp {
    display: none;
}

img {
    max-width: 100%;
}

.navbar-brand img {
    height: 50px;
}

.navbar-expand-md .navbar-toggler {
    display: block;
    border-color: #000;
    color: #000;
}

/* ================ Bootstrap overwrite ================ */
h2 {
    margin: 0 0 15px;
    font-size: 1.3rem;
}

h3 {
    margin: 0 0 15px;
    font-size: 1.2rem;
}

.btn {
    border-radius: 20px / 50%;
    padding-left: 2rem;
    padding-right: 2rem;
}

/* ================ Bootstrap overwrite ================ */
body {
    font-family: 'Lato', 'Noto Sans JP', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

header {

}

main {

}

footer {

}

/* ================ Login ================ */
#login-area {
    width: 100vw;
    height: 100vh;
}

body.rocket #login-area {
    background-color: #fdd000;
    background-image: url(../images/login/bg_main.png);
    background-repeat: no-repeat;
    background-position: top right;
    background-size: contain;
}

/* ================ Index ================ */
.info {
    padding: 20px;
    border: solid 4px #fff;
    border-radius: 10px;
}

.info ul li {
    margin: 0 0 8px;
    font-size: 1.1rem;
}

.info ul li .date {
    margin: 0 15px 0 0;
}

.mypage table th {
    padding: 3px 10px;
    text-align: center;
}

.mypage table td {
    padding: 3px 10px;
}

#myTab {
    margin: 40px 0 0;
}

#myTab li {
    width: 50%;
    border: solid 3px #fff;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    background: #fdd000;
    box-sizing: border-box;
    overflow: hidden;
    text-align: center;
}

#myTab li:last-child {
    width: 50%;
}

#myTab li .active {
    background: #fff;
    height: 100%;
}

#myTab.nav-tabs .nav-item.show .nav-link, .nav-tabs .nav-link.active {
    background-color: none;
    border-color: transparent;
}

#myTabContent .tab-pane {
    margin: 0 0 40px;
    padding: 20px;
    background: #fff;
    box-sizing: border-box;
}

#myTabContent .nowMonth {
    margin: 20px 0 10px;
    font-size: 1.3rem;
}

#myTabContent .nowMonth span {
    margin: 0 0 0 15px;
    font-size: 3rem;
}

#myTabContent table {
    width: 100%;
    border: solid 1px #000;
    text-align: center;
    table-layout: fixed;
}

#myTabContent table th {
    width: 14%;
}

#myTabContent table th, #myTabContent table td {
    padding: 15px 0;
    border-right: solid 1px #000;
    border-bottom: solid 1px #000;
}

#myTabContent table td.holiday {
    background-color: #FEF;
}

#myTabContent table td div.holiday {
    color: #dc3545;
    font-size: 0.7em;
}

#myTabContent table td div.absent {
    color: #00F;
    font-size: 0.7em;
}

#myTabContent table td div.care {
    color: #027e02;
    font-size: 0.7em;
}

#absent_cancel {
  margin-top:10px;
}
#absent_cancel .btn {
  padding:0;
}

/* Small devices (landscape phones, 576px and up) */
@media (min-width: 576px) {

}

/* Medium devices (tablets, 768px and up) */
@media (min-width: 768px) {

}

/* Large devices (desktops, 992px and up) */
@media (min-width: 992px) {

}

/* Extra large devices (large desktops, 1200px and up) */
@media (min-width: 1200px) {

}
