@import url(https://fonts.googleapis.com/css?family=Source+Sans+Pro:400,700&subset=latin,latin-ext);

/*
@page {
   size: A4;
   margin: 2.5cm;
}
*/
@media print {
   body {
      margin: 2.5cm;
   }
}

html,
body {
   margin: 0;
   padding: 0;
   font-family: 'Source Sans Pro', sans-serif;
   font-size: 100%;
   color: #505050;
   line-height: 140%;
   -webkit-text-size-adjust: 100%;
   /*Fixade ett problem för RoosT...*/
}

::selection {
   background: #909090;
}

PRE {
   background: #FFFFFF;
   font-family: monospace;
   font-size: 1em;
   white-space: pre;
}

FORM {
   margin: 0px;
   padding: 0px;
   font-size: 1em;
   font-family: 'Source Sans Pro', sans-serif;
}

fieldset {
   border: none;
   padding: 0;
   margin: 0;
}

select {
   margin: 2px;
   min-height: 34px;
   border: 0px;
   padding: 7px;
   outline: 1px solid #dcdcdc;
   outline-offset: 0px;
   font-size: 1em;
   line-height: 2em;
   font-family: 'Source Sans Pro', sans-serif;
   color: #505050;
   background: #fff;
   transition: outline 0.2s;
   min-width: 100px;
   max-width: 300px;
}

select:hover {
   background: #f4f4f4;
}

input[type=text],
input[type=password],
input[type=time],
input[type=text]:focus,
textarea,
input[type=file] {
   margin: 2px;
   border: 0px;
   padding: 7px;
   outline: 1px solid #dcdcdc;
   outline-offset: 0px;
   font-size: 1em;
   font-family: 'Source Sans Pro', sans-serif;
   color: #505050;
   transition: outline 0.2s;
}

.no_outline {
   outline: 0;
}

.filtruta {
   border: 0px;
   padding: 0px;
   outline: 1px solid #dcdcdc;
   outline-offset: 0px;
}

input[type=text]:focus,
input[type=password]:focus,
select:focus {
   outline: 2px solid #1a80b6;
   outline-offset: 0px;
   transition: outline 0.2s;
}

.disabled,
input:disabled,
select:disabled,
textarea:disabled {
   background: #f5f5f5;
   color: #505050;
   /* -webkit-text-fill-color: #505050; */
   outline: none;
   margin: 2px;
   border: 0;
   padding: 7px;
   font-size: 1em;
   font-family: 'Source Sans Pro', sans-serif;
   opacity: 1;
   min-height: 22px;
   word-wrap: break-word;
   /* max-width:80%; 211123 */
   width: 80%;
}

input:-webkit-autofill {
   -webkit-box-shadow: 0 0 0px 1000px white inset;
}

.autocomplete-suggestions {
   overflow: auto;
   -webkit-overflow-scrolling: touch;
   overflow-y: scroll;
}

.kol2_286 {
   width: 50%;
   padding: 0 0 10px 0px;
}

.errfield {
   color: #ff8585;
}

.ski,
.err {
   background: #ffc3c3;
}

.warn {
   background: #f4ed73;
}

.warn2 {
   background: #f4c073;
}

.erruta {
   margin: 10px 0 10px 0;
   padding: 10px;
   background: #ffc3c3;
   border: 1px solid #ff8585;
   width: 50%;
}

.inforuta {
   margin: 10px 0 10px 0;
   padding: 10px;
   background: #e8e8e8;
   border: 1px solid #d2d2d2;
   width: 50%;
}

.warnruta {
   margin: 10px 0 10px 0;
   padding: 10px;
   background: #fffa90;
   border: 1px solid #f4ed73;
   width: 50%;
}

.klarruta {
   margin: 10px 0 10px 0;
   padding: 10px;
   background: #aad2aa;
   border: 1px solid #9bc89b;
   width: 50%;
}

.rutabred {
   width: 70%;
}

table.ramcell {
   border-width: 0px;
   border-style: none;
   border-collapse: collapse;
}

table.ramcell td {
   border-width: 1px;
   padding: 3px;
   border-style: solid;
   border-color: black;
}

.ymlist {
   padding: 2px 0 2px 0;
}

/***** EGNA RADIO OCH CHECKBOX *************/
input[type="checkbox"],
input[type="radio"] {
   display: none;
}

input[type="checkbox"]+label span {
   display: inline-block;
   width: 26px;
   height: 26px;
   margin: -2px 0px 0 0;
   vertical-align: middle;
   background: url(/img/RochC4.png) left top no-repeat;
   cursor: pointer;
}

input[type="radio"]+label span {
   display: inline-block;
   width: 26px;
   height: 26px;
   margin: -1px 4px 0 6px;
   vertical-align: middle;
   background: url(/img/RochC4.png) -52px top no-repeat;
   cursor: pointer;
}

.rcafter {
   margin-left: 10px;
}

input[type="checkbox"]:checked+label span {
   background: url(/img/RochC4.png) -26px top no-repeat;
}

input[type="radio"]:checked+label span {
   background: url(/img/RochC4.png) -78px top no-repeat;
}

.helpicn {
   position: relative;
   margin: 8px 0 0 10px;
}

.icnclose {
   float: right;
   padding-right: 0px;
   padding-top: 10px;
   cursor: pointer;
}

.icnclose:hover,
.icn:hover,
.hover:hover {
   opacity: 0.5;
   transition: opacity 0.2s;
   cursor: pointer;
}

.icn {
   cursor: pointer;
   border: none;
   line-height: 0px;
   position: relative;
   top: 2px;
}

H1 {
   font-size: 1.875em;
   line-height: 120%;
   font-weight: 700;
   margin: 0px 0px 10px 0px;
   padding: 0px;
   font-family: 'Source Sans Pro', sans-serif;
   text-align: left;
   clear: both;
}

H2 {
   font-size: 1.625em;
   line-height: 120%;
   font-weight: 700;
   margin: 0px 0px 10px 0px;
   font-family: 'Source Sans Pro', sans-serif;
   text-align: left;
}

H3 {
   /*font-size: 1.375em;*/
   font-size: 1.25em;
   line-height: 120%;
   font-weight: 700;
   margin: 0px 0px 5px 0px;
   font-family: 'Source Sans Pro', sans-serif;
   text-align: left;
}

H3.frub {
   font-size: 1.25em;
   font-weight: bold;
   padding: 6px 0px 4px 5px;
   margin: 0px;
   font-family: 'Source Sans Pro', sans-serif;
}

H4 {
   font-family: 'Source Sans Pro', sans-serif;
   font-size: 1.125em;
   line-height: 120%;
   font-weight: 700;
   margin: 0px 0px 5px 0px;
   padding: 0px;
   text-align: left;
}

H4.frub {
   font-size: 1.125em;
   font-weight: bold;
   padding: 6px 0px 4px 4px;
   margin: 0px;
   font-family: 'Source Sans Pro', sans-serif;
}

H5 {
   font-family: 'Source Sans Pro', sans-serif;
   font-size: 1em;
   font-weight: 700;
   margin: 0px 0px 5px 0px;
   padding: 0px;
   text-align: left;
}

H6 {
   font-family: 'Source Sans Pro', sans-serif;
   font-size: 1em;
   font-weight: 400;
   font-style: italic;
   margin: 0px 0px 5px 0px;
   padding: 0px;
   text-align: left;
}

.frub {
   font-size: 1em;
   font-weight: bold;
   padding: 6px 0px 4px 4px;
   margin: 0px;
   font-family: 'Source Sans Pro', sans-serif;
}

HR {
   width: 99%;
   text-align: left;
   margin: 4px 0 4px 0;
   border: 0;
   height: 0;
   border-bottom: 1px solid #d2d2d2;
}

B,
STRONG {
   font-weight: 700;
}

.small {
   font-size: 80%;
}

.rtxt {
   padding: 5px;
}

.nowrap {
   white-space: nowrap;
}

P {
   margin: 0px 0px 5px 0px;
   padding: 0px;
   font-family: 'Source Sans Pro', sans-serif;
   font-size: 1em;
}

.justerad {
   text-align: justify;
}

table.form {
   /*border-collapse:collapse;*/
   max-width: 98%;
   /*border:1px solid white;*/
}

table.form td {
   padding: 4px;
   word-break: break-word;
}

table.form tr {
   padding: 0;
   margin: 0;
}

.formrub {
   font-weight: bold;
   width: 1%;
   white-space: nowrap;
}

.wrap {
   white-space: normal;
}

.forkl {
   font-size: 0.9em;
   font-weight: normal;
   position: relative;
   bottom: -6px;
}

/* table tr.formwarn {
   display: none;
} */

table span.formwarn {
   display: inline-block;
   padding: 5px 10px 5px 10px;
   background: #fffa90;
   border: 1px solid #f4ed73;
}

.formdta {
   display: flex;
}

.formdta_wrap {
   flex-wrap: wrap;
}

.formdta div50 {
   flex: 0 1 auto;
   width: 100%;
}

.formdta div.info {
   flex: 0 0 1%;
   padding-top: 8px;
}

.formdta .fildef {
   cursor: pointer;
   text-decoration: underline;
}

table.sorttable {
   border-collapse: collapse;
   margin-bottom: 10px;
}

table.sorttable td {
   padding: 5px;
   border: 1px solid #eee;
}

table.sorttable th.nobord {
   padding: 5px;
   border: none;
}

table.sorttable td.nb {
   border: none;
}

table.sorttable .noborder {
   border: none;
}

/*
table.sorttable tr:nth-child(even) {
   background-color: #eee;
}
*/
table.sorttable caption {
   text-align: left;
   font-weight: bold;
   font-size: 1.08em;
   padding: 6px 0 4px 5px;
}

.center {
   text-align: center;
}

.tunnram {
   border-collapse: collapse;
   border: 1px solid #000;
   font-size: 1.1em;
}

th {
   text-align: left;
   font-weight: bold;
   white-space: nowrap;
   cursor: pointer;
   padding: 5px;
   border-bottom: 1px solid #eee;
}

th span.info {
   cursor: pointer;
   border-bottom: 1px dashed #999;
}

th.datatable {
   cursor: default;
}

th.sortupp {
   padding-left: 15px;
   background: url(/img/sortupp.png) no-repeat 5px 10px;
}

th.sortner {
   padding-left: 15px;
   background: url(/img/sortner.png) no-repeat 5px 10px;
}

td.tdclick {
   text-decoration: underline;
   cursor: pointer;
}

.nolinkul td.tdclick {
   text-decoration: none;
   cursor: pointer;
}

td.tdclick:hover {
   background: #e8e8e8;
   color: #000;
}

.l1 {
   background: #f4f4f4;
}

.l2 {
   background: #fff;
}

.l3 {
   background: #cecece;
}

.felsvar {
   background: #d2aaaa
}

.rattsvar {
   background: #aad2aa !important;
}

.yel {
   background: #f4ed73
}

.idag {
   background: #f4ed73
}

A {
   text-decoration: none;
   color: #1a80b6;
   font-family: 'Source Sans Pro', sans-serif;
   font-size: 1em;
   cursor: pointer;
}

A:hover {
   color: #1a80b6;
   text-decoration: underline;
}

.clear0 {
   clear: both;
   margin: 0px;
   padding: 0px;
   height: 0px;
}

.popbg,
.mtop {
   background: #FFF url("/img/pophead.gif");
   background-repeat: repeat-x;
   margin: 2px 4px 2px 4px;
}

/* Menysaker */
.msok {
   padding: 9px 0 0 20px;
   height: 30px;
   background: #fff;
   color: #505050;
   font-weight: bold;
   border: 1px solid #d2d2d2;
   border-top: none;
   border-left: none;
}

.mflikrub {
   padding: 9px 0 0 20px;
   height: 30px;
   background: #1a80b6;
   color: #fff;
   font-weight: bold;
   border: 1px solid #d2d2d2;
   border-top: none;
   border-left: none;
   cursor: pointer;
}

.mflikrubsfi {
   background: #ed1c51;
}

.mflikrubportal {
   background: #eea944;
}

.mflikrub:hover {
   text-decoration: underline;
}

.msubrub {
   padding: 9px 0 0 20px;
   height: 30px;
   cursor: pointer;
   background: #e8e8e8 url(/img/mrubsel.png) no-repeat right center;
   border: 1px solid #d2d2d2;
   border-top: none;
   color: #505050;
}

.msubrub:hover {
   color: #000;
   text-decoration: underline;
}

.msub {
   display: none;
}

.msubsel {
   background: #e8e8e8 url(/img/mrubsel2.png) no-repeat right center;
   color: #000;
}

.mprog {
   padding: 9px 0 0 20px;
   height: 30px;
   cursor: pointer;
   background: #f4f4f4;
   color: #505050;
   border: 1px solid #d2d2d2;
   border-top: none;
}

.mprog:hover {
   color: #000;
   text-decoration: underline;
}

/* Statusikon för meny*/
.menustatus {
   display: none;
   position: relative;
   top: 2px;
   padding-left: 10px;
   color: #f00;
   font-size: 1.5em;
   line-height: 0;
}

.menuinner {
   padding: 0px;
   margin: 0;
}

/* Slut meny*/

/** Internmeny*/
.sidrubrik {
   color: #505050;
   font-size: 90%;
   padding: 9px 0px 3px 6px;
   width: 98%;
}

.sidrubrik .ll {
   float: left;
}

.sidrubrik .rr {
   float: right;
   padding-right: 9px;
   font-style: italic;
}

.intyttre {
   padding: 9px 0 10px 0;
}

.intmeny {
   padding: 6px;
   text-decoration: none;
   color: #1a80b6;
   margin: 0 10px 0 0;
   cursor: pointer;
}

.intmeny:hover {
   color: #1a80b6;
   text-decoration: underline;
}

.menuhilight {
   color: #9a0f17;
}

.menuhilightrad3 {
   color: #9a0f17 !important;
}

.imwis {
   margin-right: 0;
   border-right: none;
}

.intwrap {
   display: inline;
   position: relative;
   white-space: nowrap;
}

.intsub {
   padding: 6px;
   padding-left: 8px;
   background: url(/img/imnerx.png) no-repeat 2px 15px;
   margin: 0 10px 0 0;
   cursor: pointer;
}

.intsub:hover {
   background: url(/img/imnerx_sel.png) no-repeat 2px 15px;
   text-decoration: none;
}

.intsubut {
   position: absolute;
   top: 32px;
   left: 0px;
   width: 280px;
   border: 1px solid #d2d2d2;
   border-bottom: none;
   display: none;
   cursor: pointer;
   z-index: 500;
}

.isurad {
   border-bottom: 1px solid #d2d2d2;
   background: #e8e8e8;
   padding: 6px;
   color: #505050;
}

.isurad:hover {
   color: #000;
   text-decoration: underline;
}

.intrad3 {
   font-size: 0.95em;
}

.intrad3 .mnu {
   display: inline;
   padding: 0 0 0px 6px;
   color: #1a80b6;
   margin: 0 10px 0 0;
   cursor: pointer;
}

.intrad3 .mnu:hover {
   text-decoration: underline;
}

/** Slut Internmeny*/

.eknapp {
   font-size: 1em;
   line-height: 120%;
   cursor: pointer;
   display: inline-block;
   text-decoration: none;
   font-weight: normal !important;
   text-transform: none !important;
   border-radius: 0 !important;
   padding: 8px 18px 7px 18px;
   margin: 4px 8px 4px 0;
   color: #505050;
   background: #f0f0f0;
   border: 1px solid #dcdcdc;
}

.eknapp:hover {
   color: #fff;
   background: #1a80b6;
   border: 1px solid #00aaaa;
   text-decoration: none;
}

.eknappejmarg {
   margin: 0;
}

.eknappl {
   cursor: pointer;
   display: inline-block;
   /*padding:4px 8px 4px 8px;*/
   padding: 0;
   margin: 4px 4px 4px 0px;
   color: #505050;
   background: #f0f0f0;
   border: 1px solid #dcdcdc;
}

.eknappl span {
   display: inline-block;
   font-size: 80%;
   line-height: 100%;
   padding: 3px 8px 5px 8px;
   text-decoration: none;
   font-weight: normal;
}

.eknappl span i {
   /*För font awesome*/
   padding-right: 4px;
}

.eknappl:hover span i {
   color: #fff;
}

.eknapp:hover,
.eknappl:hover {
   color: #fff;
   background: #012646;
   text-decoration: none;
   border: 1px solid #012646;
}

.markera {
   border: 1px solid red;
}

.submenu {
   padding: 3px 3px 3px 3px;
}

.left {
   display: block;
   float: left;
}

.right {
   display: block;
   float: right;
}

.halvyta {
   width: 480px;
   float: left;
}

.clear {
   clear: both;
}

.hide {
   display: none;
   background: #0F0;
}

.nodisplay {
   display: none;
}

/* MAIN-div */
.main {
   position: relative;
   width: 100%;
   background: #fff;
   overflow: hidden;
}

.innerpad {
   padding: 15px;
}



.header {
   position: relative;
   height: 60px;
   padding: 0;
   margin: 0;
   border-bottom: 10px solid #e8e8e8;
}

.footer {
   position: relative;
   background: #373737;
   height: 60px;
   padding: 0;
   margin: 0;
   color: #fff;
}

.inlsom {
   float: left;
   padding: 18px 0 0 20px;
}

.inlsom .ikon {}

.inlsom .pers {
   position: relative;
   color: #8c8c8c;
   font-weight: bold;
   top: -5px;
   padding: 0 0 0px 8px;
}

.urval {
   float: right;
   color: #8c8c8c;
   font-weight: bold;
   padding: 18px 20px 0 0;
   cursor: pointer;
}

.urval:hover {
   opacity: 0.5;
   transition: opacity 0.2s;
}

.info {
   cursor: pointer;
}

.info img {
   position: relative;
   top: 3px;
}

.info:hover {
   opacity: 0.5;
}

.logotop {
   padding-top: 15px;
   margin-left: auto;
   margin-right: auto;
   width: 90px;
}

.topicny {
   position: absolute;
   right: 0px;
   top: 20px;
   cursor: pointer;
}

.topicn {
   float: right;
   padding-top: 4px;
   padding-right: 10px;
   padding-left: 10px;
}

.titxt {
   position: relative;
   font-weight: bold;
   padding: 0 0 0 5px;
   top: -6px;
}

.topicn:hover {
   opacity: 0.5;
   transition: opacity 0.2s;
}

.menu2 {
   position: absolute;
   left: 20px;
   top: 21px;
   display: none;
   cursor: pointer;
}

.menu2 .txt {
   font-weight: bold;
   position: relative;
   left: 8px;
   top: -2px;
}

.menu2:hover {
   opacity: 0.5;
   transition: opacity 0.2s;
}

.content {
   position: absolute;
   border: 0;
   padding: 0;
   left: 270px;
   margin: 0;
   top: 0px;
   height: 100%;
   overflow: hide;
   /*outline:1px dotted red;*/
}

.icontent {
   display: inline;
   border: 0;
   padding: 0 5px 0 10px;
   margin: 0;
   height: 100%;
   width: 100%;
   max-width: 100%;
}

.icofix2 {
   margin-top: 5px;
}

@media (max-width: 760px) {

   /*
   H1 {font-size:6vw;}
   H2 {font-size:5vw;}
   H3, H4, H5, H6 {font-size:4vw;}
*/
   .erruta {
      width: 90%;
   }

   .inforuta {
      width: 90%;
   }

   .warnruta {
      width: 90%;
   }
}

/*DELTAGARÖVERSIKT*/
.npoversikt {
   display: flex;
   /* margin-left: 20px; */
   padding-left: 5px;
   gap: 10px;
   border-left: 4px solid #ddd;
}

.npoversikt .rub {
   font-size: 0.8em;
   font-weight: 600;
}

/*STARTSIDA*/
.nyhet_container {
   display: flex;
   flex-flow: row wrap;
}

.nyhet_container .nyhet {
   position: relative;
   flex: 0 0 auto;
   width: 219px;
   padding: 30px 8px 8px 8px;
   margin: 10px 10px 10px 0;
   background: #f5f5f5;
   cursor: pointer;
}

.nyhet_container .nyhet .datum {
   position: absolute;
   left: 8px;
   top: 8px;
   font-size: 0.8em;
   font-weight: bold;
}

@media only screen and (max-width: 720px) {
   .nyhet_container .nyhet {
      width: 95%;
   }
}

.startrutor {
   display: flex;
   flex-flow: row wrap;
   margin-left: 10px;
}

.startrutor .ruta {
   position: relative;
   flex: 0 0 auto;
   width: 219px;
   padding: 8px 8px 25px 8px;
   margin: 10px 10px 10px 0;
   background: #f5f5f5;
   height: 90px;
}

.startrutor .ruta .rub {
   font-weight: bold;
}

.startrutor .ruta .antal {
   position: absolute;
   right: 8px;
   bottom: 8px;
   font-weight: bold;
}

.startrutor .ruta.sel {
   outline: 3px solid #1a80b6;
}

.startrutor .ruta:hover {
   opacity: 0.5;
   transition: opacity 0.2s;
   cursor: pointer;
}

@media only screen and (max-width: 720px) {
   .startrutor .ruta {
      width: 95%;
   }
}

/*-------------------------------NÄRVAROHANTERING */
.narvhant {
   width: 100%;
}

.narvhant .narvtop {
   position: absolute;
   box-sizing: border-box;
   top: 45px;
   width: 98%;

   height: 95px;
   /* border: 2px solid #eee; */
}

.narvtop table {
   width: 50%;
}

.narvhant .sorttable {
   width: 100%;
}

.narvhant .sorttable .mo {
   text-align: center;
   cursor: pointer;
}

.narvhant .sorttable .val1 {
   text-align: center;
   font-weight: bold;
   background-color: #f4f4f4;
   width: 1%;
   white-space: nowrap;
}

.narvhant .sorttable .mo:hover {
   background: #e8e8e8;
}

.narvhant .narvyta {
   position: absolute;
   top: 150px;
   overflow-y: scroll;
   width: 98%;
   height: calc(100% - 150px);
}

/*-------------------------------LMS */
.sorttable .lmsmoment {
   background: #eee
}

.md_meny {
   .md_meny_pkt {
      color: #1a80b6;
      padding: 6px;
      cursor: pointer;
      position: relative;
      display: inline;
   }

   .md_meny_pkt:hover {
      text-decoration: underline;
   }
}

.md_bildval,
.md_filval,
.md_mallval {
   position: absolute;
   background-color: #fff;
   border: 1px solid black;
   box-shadow: 5px 5px 5px grey;
   width: 420px;
   height: 300px;
   z-index: 500;
   display: none;
   padding: 5px;
   overflow-y: auto;
}

.lms_bildval {
   display: flex;
   flex-wrap: wrap;
   width: 400px;
}

.lms_bildval img {
   flex: 0 1 auto;
   display: block;
   max-width: 80px;
   cursor: pointer;
   padding: 4px;
}

.lms_fil {
   padding: 4px 0 0 0;
   cursor: pointer;
}

.lms_mall {
   margin-bottom: 5px;
}

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

.lms_mall .beskr {
   padding-left: 10px;
}

.lms_pop_head {
   height: 33px;
   background: #eee;
   background: #1A80B6 url(/img/popstang.png) 4px 4px no-repeat;

   margin: 0 0 5px 0;
   cursor: pointer;

}

.lms_km img {
   max-width: 100%;
}

.lms_km .fallut {
   border: 2px solid#1A80B6;
   border-radius: 10px;
   padding: 10px 10px 5px 10px;
   font-size: 1em;
   background: #fff;
   margin: 5px 0 10px 0;
}

.lms_km .fallut .furubrik {
   display: flex;
}

.lms_km .fallut .fupil {
   flex: 0;
}

.lms_km .fallut .rubrik {
   flex: 1;
   color: #1f65ab !important;
   font-size: 1em;
   line-height: 120%;
   font-weight: 600;
   margin: 0px 0px 5px 0px;
   font-family: "Montserrat", sans-serif;
   letter-spacing: 0.5px;
   width: calc(100% - 20px);
}

.lms_km .fallutinh {
   display: none;
}

.avdelare {
   margin: 20px auto 20px auto;
   width: 15%;
   border-bottom: 4px solid #1F65AB;
}

.tankpa {
   position: relative;
   outline: 5px solid #1F65AB;
   outline-offset: -15px;
   padding: 38px 30px 22px 30px;
   margin: 18px 0 5px 0;
}

.tankpa::after {
   content: "";
   position: absolute;
   top: -5px;
   left: 0px;
   width: 137px;
   height: 34px;
   background: url(/img/tankpa3.svg) no-repeat;
}