﻿html, body, #app, .outer-wrapper, .viewer-tab, .viewer-wrapper {
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.sidebar {
    display: none;
}

#app {
    background-color: #333;
}

.viewer-wrapper {
    overflow: hidden;
    background-color: #333;
    padding: 0px;
    width:100%;
    resize:none;
}

.viewer-content, .viewer-broken {
    overflow: scroll;
    width: 100%;
    height: calc(100% - 80px);
    text-align: center;
    touch-action:pan-x, pan-y;
    
}

.viewer-code {
    width: 100%;
    height: calc(100% - 80px);
    font-size: 80%;
}

.viewer-canvas {
    box-shadow: 10px 10px 5px #111;
    visibility : hidden;
    margin: 50px 20px;

}

.viewer-controls {
    width: 100%;
    height: 40px;
    display: block;
    position: sticky;
    background-color: #222;
    padding-top: 8px;
    text-align: center;
    -webkit-user-select: none;
    user-select: none;
}

.viewer-controls-top {
    box-shadow: 0px 5px 5px #111;
    top:0px;
}

.viewer-controls-bottom {
    box-shadow: 0px -5px 5px #111;
    bottom:0px;
}

.viewer-button,
.viewer-return a{
    color: white;
    padding: 4px;
    margin: 0px 3px;
    cursor: pointer;
    border: solid 1px transparent;
}

.viewer-button:hover,
.viewer-return a:hover {
    cursor: pointer;
    border: solid 1px #aaa;
    background-color: rgba(70, 70, 70, 0.3);
    border-radius: 3px;
}

    .viewer-button:active,
    .viewer-return:active {
        background-color: rgba(30, 30, 30, 0.3);
    }



.viewer-button.disabled{
    color: #444;
    cursor: default;
    border-color: transparent;
    background-color: transparent;
}

    .viewer-button span.label {
        font-size: 80%;
        display: inline-block;
        padding-left: 5px;
        vertical-align: text-top;
    }

.viewer-nav-button {
    font-weight: 700;
}

.viewer-page-count, .viewer-page-zoom {
    color: white;
    font-size: 80%;
    font-weight: 200;
    -webkit-user-select: none;
    user-select: none;
}

.viewer-logo {
    float: left;
    padding-left: 10px;
    color: white;
    font-size: 16px;

}

.viewer-logo .oi-droplet {
    color: #00b6b6;
    padding-right: 8px;
    font-size: 20pt;
    vertical-align: bottom;
}

.viewer-logo .logo-name-first {
    font-weight: 700;
}

.viewer-logo .logo-name-second {
    font-weight: 100;
    padding-left: 3px;
    display: none;
}

.viewer-controls-pages {
    display: none;
}

.viewer-controls-action {
    float: right;
    padding-right: 10px;
}


.viewer-controls-debug, .viewer-controls-generate {
    float: right;
    padding-right: 5px;
    padding-left: 5px;
}

.viewer-code-data {
    width: calc(50% - 5px);
    height: 100%;
    float:left;
}

.viewer-code-template {
    width: calc(50% - 5px);
    height: 100%;
    float: right;
}

.viewer-code-header
{
    z-index: 1;
    background-color: #222;
    color: white;
    padding: 5px;
    position: relative;
    box-shadow: 0px 5px 5px #111;
    border-top: 1px solid #333;
    border-bottom: 1px solid #333;
}


.viewer-code-separator {
    width: 10px;
    height: 100%;
    float: left;
    position: relative;
    z-index: 1;
    background-color: #222;
    border-top: 1px solid #333;
}

/*
    viewer panels based on process
*/


/* default = none */

.viewer-none {
    display: block;
}

.viewer-broken,
.viewer-content,
.viewer-working,
.viewer-code,
.viewer-controls-bottom {
    display: none;
}


/* broken view display */

#pdf-wrapper.broken .viewer-broken,
#pdf-wrapper.broken .viewer-controls-bottom {
    display: block;
}

#pdf-wrapper.broken .viewer-content,
#pdf-wrapper.broken .viewer-working,
#pdf-wrapper.broken .viewer-none,
#pdf-wrapper.broken .viewer-code {
    display: none;
}

/* canvas view display */

#pdf-wrapper.canvas .viewer-content,
#pdf-wrapper.canvas .viewer-controls-bottom {
    display: block;
}

#pdf-wrapper.canvas .viewer-broken,
#pdf-wrapper.canvas .viewer-working,
#pdf-wrapper.canvas .viewer-code,
#pdf-wrapper.canvas .viewer-none {
    display: none;
}

/* working view display */

#pdf-wrapper.working .viewer-working {
    display: block;
}

#pdf-wrapper.working .viewer-working img {
    animation: pulse-black 2s infinite;
}

#pdf-wrapper.working .viewer-broken,
#pdf-wrapper.working .viewer-content,
#pdf-wrapper.working .viewer-none,
#pdf-wrapper.working .viewer-code,
#pdf-wrapper.working .viewer-controls-bottom {
    display: none;
}

/* working view display */

#pdf-wrapper.code .viewer-code,
#pdf-wrapper.code .viewer-controls-bottom {
    display: block;
}

#pdf-wrapper.code .viewer-broken,
#pdf-wrapper.code .viewer-content,
#pdf-wrapper.code .viewer-none,
#pdf-wrapper.code .viewer-working {
    display: none;
}



.viewer-code .CodeMirror {
    padding-bottom: 40px;
}

@keyframes pulse-black {
    0% {
        transform: scale(0.95);
        /*box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.7);*/
    }

    70% {
        transform: scale(1);
/*        box-shadow: 0 0 0 10px rgba(0, 0, 0, 0);*/
    }

    100% {
        transform: scale(0.95);
/*        box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);*/
    }
}

/* responsive code panels */

.viewer-code .viewer-code-sm-header {
    display: none;
}

    .viewer-code .viewer-code-sm-header .viewer-code-button {
        z-index: 1;
        background-color: #222;
        color: #fff;
        padding: 3px;
        position: relative;
        border: 1px solid #ccc;
        margin-right: 4px;
        margin-left: 4px;
        top: 8px;
        font-size: 80%;
        cursor: pointer;
    }

.viewer-code .viewer-code-sm-header .viewer-code-button.active {
    background-color: #ccc;
    border-color: #ccc;
    color: #333;
    cursor: default;
}

.viewer-wrapper.code .viewer-generate-button,
.viewer-wrapper.canvas .viewer-show-edit{
/*    position: absolute;*/
    right: 10px;
    background-color: #00b6b6;
    color: black;
    border-radius: 3px;
    border: solid 1px transparent;
    padding: 4px 10px;
}

.viewer-wrapper.code .viewer-generate-button:hover,
.viewer-wrapper.canvas .viewer-show-edit:hover{
    background-color: #33c9c9;
    border: solid 1px #aaa;
}

.viewer-wrapper.code .viewer-generate-button:active,
.viewer-wrapper.canvas .viewer-show-edit:active {
    background-color: #11b6b6;
}

    @media only screen and (max-width: 600px) {
        .viewer-code-header {
        display: none;
    }

    .viewer-code .viewer-code-sm-header {
        display: block;
        height: 29px;
        border-bottom: solid 2px #ccc;
    }

    .viewer-code.data .viewer-code-data {
        display: block;
        width: 100%;
    }

    .viewer-code.template .viewer-code-data {
        display: none;
    }

    .viewer-code.data .viewer-code-template {
        display: none;
    }

    .viewer-code.template .viewer-code-template {
        display: block;
        width: 100%;
    }

    .viewer-code-separator {
        display: none;
    }
}
/*
    Light theme
*/
.outer-wrapper.light .viewer-wrapper {
    background-color: #eee;
}

.outer-wrapper.light .viewer-controls,
.outer-wrapper.light .viewer-code-header{
    background-color: #ccc;
}

.outer-wrapper.light .viewer-button,
.outer-wrapper.light .viewer-page-count,
.outer-wrapper.light .viewer-page-zoom,
.outer-wrapper.light .viewer-return,
.outer-wrapper.light .viewer-return a{
    color: #111;
}

.outer-wrapper.light .viewer-button.disabled {
    color: #aaa;
}

    .outer-wrapper.light .viewer-button:hover,
    .outer-wrapper.light .viewer-return a:hover {
        cursor: pointer;
        border: solid 1px #aaa;
        background-color: rgba(30, 30, 30, 0.1);
        border-radius: 3px;
    }

    .outer-wrapper.light .viewer-button:active,
    .outer-wrapper.light .viewer-return:active {
        background-color: rgba(30, 30, 30, 0.3);
    }
.outer-wrapper.light .viewer-logo {
    color: black;
}

.outer-wrapper.light .viewer-code-header {
    color: #111;
    box-shadow: 0px 4px 4px #777;
}

.outer-wrapper.light .viewer-controls-top {
    box-shadow: 0px 4px 4px #777;
    border-bottom: 1px solid #555;
}

.outer-wrapper.light .viewer-code-button {
    background-color: #eee;
    color: #333;
}

.outer-wrapper.light .viewer-controls-bottom {
    box-shadow: 0px -4px 4px #777;
    border-top: solid 1px #555;
}

.outer-wrapper.light .viewer-logo .oi-droplet {
    color: #00b6b6;
}

.outer-wrapper.light .viewer-canvas {
    box-shadow: 5px 5px 5px #555;
}




/* home page */

.index-content {
    color: #ddd;
    text-align:center;
    font-size: medium;
    font-weight:300;
    height:100%;
    overflow:auto;
    padding-bottom: 70px;
}

.index-content a {
    color: aqua;
    text-decoration: none;
}

.index-contact-form {
    padding: 10px 5vw;
}

.index-contact-form .contact-section{
    padding-bottom: 10px;
    flex-basis: 100%;
    flex-grow: 1;
    margin: 10px;
}

.index-contact-form .contact-section.contact-reason,
.index-contact-form .contact-section.contact-notes,
.index-contact-form .contact-section.contact-domain {
    flex-grow: 2;
}

.index-contact-form .index-contact-fields {
    width: 100%;
    text-align: left;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: stretch;
    flex-direction: row;
    max-width: 800px;
    margin:auto;
}

.index-contact-form .contact-submit {
    width:100%;
    max-width: 800px;
    margin:auto;
    text-align:right;
    padding-right: 10px;
}

    .index-contact-form .index-contact-done {
        background-color: #444;
        color: white;
        text-align:center;
        border-radius: 2vw;
        margin-bottom: 50px;
        display:none;
    }

    .index-contact-form .contact-section input,
    .index-contact-form .contact-section select,
    .index-contact-form .contact-section textarea {
        background-color: white;
        font-size: x-large;
        width: 100%;
        border: solid 1px black;
        border-radius: 10px;
        padding-left: 2px;
    }

.index-contact-form .contact-section input,
.index-contact-form .contact-section select {
    height: 48px;
}

.index-contact-form .contact-section textarea {
    height: 144px;
    font-size:x-large;
}

.index-contact-form .contact-section label {
    font-size: x-large;
    display: block;
}

.index-contact-form .contact-section .req {
    color:aqua;
    padding: 5px;
    font-weight:900;
}

    .index-contact-form .contact-section .contact-submit-error {
        color: aqua;
        font-size: large;
        font-weight: 600;
        display:block;
        text-align:left;
        visibility:hidden;
    }

    .index-contact-form .contact-section button {
        background-color: aqua;
        color: #222;
        padding: 10px;
        border-radius: 5px;
        border: solid 1px #222;
        margin-top: 20px;
        margin-bottom: 50px;
        font-size: x-large;
    }

.index-logo .oi {
    font-size: 15vw;
    color: aqua;
    display: block;
    padding: 2vw;
}

.index-logo .logo-name {
    font-size:5vw;
    display:block;
}

.index-logo .logo-mission,
.index-desc {
    font-size: 3vw;
    display: block;
    font-style: italic;
}


.index-disclaim {
    background-color: #444;
    background-image: linear-gradient(#444, #333, #444);
    border-radius: 2vw;
    color: white;
    font-size: 2vw;
    font-weight:500;
    max-width: 80vw;
    margin: auto;
    margin-top: 4vw;
    padding: 3vw;
    margin-bottom: 50px;
}

.index-disclaim p {
    border-top: solid 1px #888;
    text-align: left;
    margin-top: 4vw;
    padding-top: 4vw;
}

.index-features {
    display:flex;
    flex-wrap: wrap;
    max-width: 100vw;
    margin:0px;
    padding: 10vw;
    background-color: #444;

}

.index-title {
        width: 100%;
        font-size: 4vw;
        padding: 1vh 4vh 2vh 4vh;
    }

.index-desc {
    font-size: 2vw;
    display: block;
    font-style: italic;
    width: 100%;
    text-align: center;
    margin-bottom: 2vw;
}

.index-desc .button {
    border: solid 1px aqua;
    padding: 1vw 2vw;
    background-color: #333;
    color: white;
    font-style: normal;
}

    .index-desc .button:hover {
        box-shadow: 5px 5px 5px #111;
    }
    .index-desc .button:active {
        box-shadow: none;
    }


.index-features .index-feature {
    flex-grow: 1;
    width: 37vw;
    margin: 1.5vw;
    border: solid 1px transparent;
}

    .index-features .index-feature:hover {
        border: solid 1px black;
        box-shadow: 5px 5px 5px #111;
    }

    .index-features .index-feature .oi {
        display: block;
        color: #05696B;
        font-size: 150%;
    }
    .index-features .index-feature strong {
        display: block;
        margin-bottom: 10px;
        color: #05696B;
        border-bottom: solid 1px #05696B;
        padding-bottom: 10px;
    }


.index-contact-us {
    margin-top: 3vh;
    background-color: #444;
}

.index-contact-form {
    text-align:left;
}



@media only screen and (max-width: 1200px) {

    .index-disclaim {
        font-size: 2.5vw;
    }

    .index-features .index-feature {
        width: 30%;
        margin-bottom: 30px;
    }

    .index-features .index-title,
    .index-about .index-title,
    .index-about-us .index-title,
    .index-contact-us .index-title {
        width: 100%;
        font-size: 5vw;
        padding: 4vw;
    }


    .index-logo .oi {
        font-size: 20vw;
        padding: 4vw;
    }

    .index-logo .logo-name {
        font-size: 6vw;
    }

    .index-logo .logo-mission,
    .index-desc {
        font-size: 3vw;
    }
    
}
@media only screen and (max-width: 900px) {
    .index-features .index-feature {
        width: 90%;
    }
}

@media only screen and (max-width: 600px) {

    .index-disclaim {
        font-size: 3vw;
    }

    

    .index-features .index-title,
    .index-about .index-title,
    .index-about-us .index-title,
    .index-contact-us .index-title {
        width: 100%;
        font-size: 6vw;
        padding: 4vw;
    }

    .index-logo .oi {
        font-size: 25vw;
        padding: 6vw;
    }

    .index-logo .logo-name {
        font-size: 7vw;
    }

    
}

@media only screen and (max-width: 400px) {

    .index-disclaim {
        padding-top: 15px;
        padding-bottom: 15px;
        margin-top: 15px;
        margin-bottom: 15px;
        font-size: 10pt;
    }

    .index-features .index-feature {
        width: 90%;
    }

    .index-features .index-title,
    .index-about .index-title,
    .index-about-us .index-title,
    .index-contact-us .index-title {
        width: 100%;
        font-size: 20pt;
        padding: 20pt;
    }

    .index-logo .oi {
        font-size: 40pt;
        padding: 20pt;
    }

    .index-logo .logo-name {
        font-size: 20pt;
    }

    .index-logo .logo-mission,
    .index-desc {
        font-size: 12pt;
    }
}