@charset "utf-8";

/* HTML5 */
article, aside, canvas, details,
figcaption, figure, footer, header,
hgroup, menu, nav, section, summary {
    display: block;
}

/* --------------------
 BODY
 --------------------*/

* {
    font-family: Verdana, Helvetica,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック',sans-serif;
}

body {
    background: #fbfbfb;
    color: #4a4a4a
}

/* --------------------
 H
 --------------------*/

 h1,h2,h3,h4,h5,h6 {
    font-family: Verdana, Helvetica,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
    margin: 0;
}

/* --------------------
 FOOTER
 --------------------*/

#footer {
    margin-top: 70px;
    font-size: 75%;
}


/* --------------------
 FLOW
--------------------*/
#flow {
    height: 65px;
    width: auto;
    min-width: 960px;
    background: #ffffff;
    border: solid 1px #dddddd;
    font-size: 100%;
}

#flow .inner {
    width: 960px;
    margin: 0px auto;
}

#flow ol {
    counter-reset:number;
    list-style:none;
    margin: 20.5px 0;
    padding:0;
}

#flow ol li {
    float: left;
    color: #888888;
    padding: 0;
    border: none;
}

#flow ol > li:first-of-type {
    padding-top: 0;
    background: none;
}

#flow ol > li:last-of-type {
    background: none;
}

#flow ol > li p {
    font-size: 100%;
}

#flow ol li.active{
    color: #444;
}

#flow ol li:before{
    counter-increment: number;
    content: counter(number);
    margin-right: 15px;

    width: 1.5em;
    height: 1.5em;
    border-radius: 50%;
    text-align: center;
    line-height: 1.5;
}

#flow ol li.active:before {
    margin: 0 8px 0 -7px;
    float: left;
    background: #2c71a5;
    width: 1.5em;
    height: 1.5em;
    border-radius: 50%;
    color: #fff;
    text-align: center;
    line-height: 1.5;
}

#flow .separator {
    padding: 0px 20px;
    background: url("images/arrow.png") no-repeat center;
}

/* MUST */
.rack .must th,
th.must{
    background:
        url("images/rack/label.png") no-repeat 141px center;
}

.rack .long-must th
{
    background:
        url("images/rack/label.png") no-repeat 200px center;
}

/* OPTIONAL*/
.rack .optional th,
th.optional {
    background:
        url("images/rack/optional.png") no-repeat 141px center;
}

/* --------------------
 SHELF
 --------------------*/

section .shelf {
    border: 1px solid #ddd;
    background: #fff;
    border-radius: 5px;
    padding: 15px;
}

/* --------------------
 H1
 --------------------*/

 h1 {
     margin: 0 auto 0 0;
     min-height: 0;
     width: 960px;
     color: #2c71a5;
     font-weight: bold;
     font-size: 32px;
     line-height: normal;
     text-align: center
 }

/* --------------------
 H2
 --------------------*/

h2 {
    margin-bottom: 15px;
    padding-left: 12px;
    border-left: 6px solid #2c71a5;
    font-weight: bold;
    font-size: 20px;
}

/* --------------------
 LABEL
 --------------------*/

label {
    height: 35px;
    line-height: 35px;
    font-size: 14px;
}

/* --------------------
 INPUT
 --------------------*/

input[type="text"],
input[type="password"],
input[type="button"] {
    height: 35px;
    border: 1px solid #DDD;
    border-radius: 4px;
    padding: 0 10px;
    outline: none;
    color: #555;
    line-height: 35px\9;
}

/* ブロック要素input*/
.input-block{
    width:100%;
  -webkit-box-sizing: border-box;
   -khtml-box-sizing: border-box;
     -moz-box-sizing: border-box;
      -ms-box-sizing: border-box;
          box-sizing: border-box;
}

input.long {
    width: 429px;
}
input.middle {
    width: 195px;
}
input.short {
    width: 85px;
}
input.mini {
    width: 50px;
}
input:focus {
    background: #fefed7;
}

/* --------------------
 A
-------------------- */
a {
    color: #2c71a5;
    text-decoration: none;
}

/* --------------------
 SELECT
-------------------- */

select {
    -moz-appearance: button;
    appearance: button;
    height: 35px;
    line-height: 35px !important;
    vertical-align: middle !important;
    border-radius: 3px;
    padding: 0 0 0 5px;
    outline: none;
}

/* Chrome & Safari */
@media screen and (-webkit-min-device-pixel-ratio:0) {
    select  {
        height: 35px ;
        -webkit-appearance: button;
        appearance: button;
        border-radius: 4px;
        border: 1px solid #bfbfbf;
        padding-left: 10px;
        background:
            url("images/rack/select.png")
            no-repeat
            right;
        font-size: 14px;
        outline: none;
    }
}

.light select {
    border: 1px solid #ccc;
}
.dark select {
    border: 1px solid #666;
}
select.grande {
    width: 350px;
}
select.long {
    width: 215px;
}
select.middle {
    width: 105px;
}
select.short {
    width: 70px;
}
select.flex {
    min-width: 105px;
}

/* --------------------
 SECTION
 --------------------*/

 body > section,
 body > form > section {
     width: 960px;
    margin: 0px auto;
 }

 #confirm > section {
     margin: 50px auto;
 }


/* --------------------
 RACK
--------------------*/

/* TABLE */
.rack {
    empty-cells: show;
    border-collapse: separate;
    border-radius: 5px;
}
.rack th {
    padding-left: 15px;
    width: 173px;
    height: 65px;
    vertical-align: middle;
    font-weight: bold;
    font-size: 14px;
    font-family: Verdana, Helvetica,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
}
.rack th h3 {
    font-weight: bold;
}
.rack td {
    vertical-align: middle;
}

.rack tr:first-child th:last-child,
.rack tr:first-child td:last-child {
    border-radius: 0 5px 0 0;
}

.rack tr:first-child th:first-child,
.rack tr:first-child td:first-child {
    border-radius: 5px 0 0 0;
}

.rack tr:last-child th:first-child,
.rack tr:last-child td:first-child {
    border-radius: 0 0 0 5px;
}

.rack tr:last-child th:last-child,
.rack tr:last-child td:last-child {
    border-radius: 0 0 5px 0;
}

table.rack.light tr:last-child td,
table.rack.light tr:last-child th {
    border-bottom: none;
}

table.rack.light tr th:last-child,
table.rack.light tr td:last-child {
    border-right: none;
}

/* LIGHT */
.rack.light {
    background: #f1f1f1;
}
.rack.light th,
.rack.light td {
    border-top: 1px solid #fff;
    border-bottom: 1px solid #ccc;
}
.rack.light input[type="button"] {
    margin-left: 15px;
    width: 157px;
    height: 37px;
    background:
        url("https://secure.sakura.ad.jp/signup3/css/services/ssl/images/rack/btn01.png")
        no-repeat;
    cursor: pointer;
}
.rack.light input[type="button"]:hover {
    background-position: 0px -35px;
}

/* EM */
.rack em {
    color: #d23a65;
    font-weight: bold;
}

/* --------------------
 NOTIFY
--------------------*/
.error-txt {
    color: #d23a65;
    font-size: 12px;
}

.rack .error {
    padding: 0 0 0 15px !important;
    height: 30px !important;
    border: 0 !important;
    background: none #d23a65 !important;
    font-weight: normal !important;
    line-height: 30px;
    color: #fff !important;
    font-size: 13px;
}

.rack .error {
    color: #fff !important;
}

/* SPAN */

.rack th span {
    font-size: 11px;
}

/* --------------------
 DISPLAY
--------------------*/

.invisible {
    display: none;
}
.visible {
    display: table-cell;
}

/* --------------------
 MODAL
--------------------*/
body .modal .modal-backdrop {
    background: none;
}

.modal .close {
    float: right;
    text-decoration: none;
    color: #444;
}

.rack.light td.desc {
    background: #e3e3e3;
    padding-left: 15px;
    width: 262px;
    vertical-align: middle;
    font-size: 11px;
}

.disabled {
    color: #888888;
}

ul li label {
    margin-right: 15px;
}

body > section+section,
body > form > section+section {
    margin-top: 25px;
}

#main-title h1 {
    background: url("images/logos/https.png") no-repeat 800px;
    padding: 40px 0;
}

#main-title+section {
    margin-top: 0;
}

.rack th span {
    font-size: 11px;
}

.shelf h3 {
    font-weight: bold;
    color: #073e6e;
    margin-bottom: 15px;
}

#submit {
    text-align: center;
}

table {
    width: 100%;
}


/* --------------------
 MessageBox
--------------------*/
.message-box {
    background: #fffbe4;
    border: solid 1px #f8f6e6;
    padding: 10px 15px;
    text-align: center;
    margin: 0 auto;
}

/* --------------------
 DarkBox
--------------------*/
.light-box {
    background: #f1f1f1;
    border-radius: 5px;
}

input[type="radio"] {
    margin-right: 10px;
}

a.new-window {
    background: url("images/linkblank.png") no-repeat right;
    background-size: 13px 12px;
    padding-right: 15px;
    margin-right: 5px;
    font-weight: bold;
}

.infomation {
    font-weight: bold;
}
.infomation:before{
    content:url("images/rack/exclamation.png");
    position: relative;
    top:2px;
    margin-right:4px;
}

.hint a {
    background: url("images/popup.png") no-repeat right;
    background-size: 13px 12px;
    padding-right: 15px;
    margin-right: 5px;
}

.modal .modal-dialog {
    width: 750px;
}

.fnt-blue {
    color: #2c71a5;
}

.btn,
#submit button {
    border: none;
    text-indent: -9999px;
    cursor: pointer;
}
.btn:hover,
#submit button:hover {
    opacity: 0.6;
}
#submit button.sent {
    opacity:0.6;
    cursor: default;
}


/* --------------------
 SUBMIT BUTTON
--------------------*/
#submit .corporation-input {
    background: url("images/btn/next/corporation.png") no-repeat;
    width: 430px;
    height: 53px;
}

#submit .csr-input {
    background: url("images/btn/next/csr.png") no-repeat;
    width: 430px;
    height: 54px;
}

#submit .confirm {
    background: url("images/btn/next/confirm.png") no-repeat;
    width: 430px;
    height: 54px;
}

#submit .commit {
    background: url("images/btn/next/complete.png") no-repeat;
    width: 430px;
    height: 54px;
}

/* 注意文言box */
.caution-box {
    padding: 0.5em 1em;
    margin: 0.2em 0 1em 0;
    font-weight: bold;
    border: solid 1px #D4440D;
    border-radius: 5px;
    font-size: 14px;
    background-color: #FFEFEF;
}