/* CSS Document */
body{ background: #FFFFFF; font-size: 100%; font-size: 13px; /*color: #343434;*/ font-weight: 300; }
a { 
	-webkit-transition: all 0.3s ease-in-out;
	-moz-transition: all 0.3s ease-in-out;
	-o-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
	color: rgb(39, 58, 225); 
}
b, strong{ font-weight: 700; }
label{ font-size: 100%; }
.content-wrapper { padding: 20px; }
/*HEADER*/
#header { background: rgb(39, 58, 225); }
#header > div { padding: 5px 20px 10px 20px; }
#header a:hover { color: rgba(255, 255, 255, 0.85); }
#logo { 
	text-decoration: none;
    font-size: 33px;
	font-family: arial;
	width: 290px;
	display: inline-block;
	font-weight: normal;
	overflow: auto;
	float: left;
	cursor: pointer;
    line-height: initial;
}
#header a#logo:hover { color: #F1F0F0; }
#logo span {
    display: block;
    font-size: 14px;
    font-weight: normal;
    float: right;
    margin-right: 5px;
}
#user-connection-area{
	display: inline-block;
	float: right;
	text-align: right;
    z-index: 2;
    position: relative;
    /*background: rgba(10, 29, 199, 1);*/
    padding: 3px 0px 5px 5px;
    margin-top: -5px;
}
#user-connection-area ul { padding: 0 0; }
#user-connection-area span{
	font-size: 13px;
	color: #bbb;
	margin-bottom: 5px;
	display: block;	
}
#user-connection-area li { display: inline-block; margin: 0 0; margin-left: 5px; color: #CCCCCC; border-left: 1px solid rgba(255, 255, 255, 0.45); padding-left: 10px; }
#user-connection-area li:first-child { border-left: none; padding-right: 0px; line-height: 10px; }
#user-connection-area > li > a { text-decoration: none; font-weight: normal; color: rgba(255,255,255,1); font-size: 90%; }
#user-connection-area .btn-group .btn{ background: none; color: white; font-size: 0.95em;}
#user-connection-area .btn-group .dropdown-toggle{ 
    background: none;
    color: white;
    border-left: 1px solid grey;
    cursor: pointer;
    height: 20px;
    margin-top: 4px;
}
#user-connection-area .btn-group .dropdown-toggle::after{
    vertical-align: top;
    margin-top: 4px;
}
#user-connection-area .dropdown-menu .dropdown-item{ color: #464646; font-weight: 300; font-size: .8rem; padding: .45rem 1.5rem; }
#user-connection-area .dropdown-menu .dropdown-item:hover{ color: #f3f3f3; background-color: #233aea; }

#search-box { clear: both; float: right; margin-top: -40px; z-index: 0; position: relative; }
#search-box span { font-size: 13px; margin-bottom: 0px; display: block; margin-top: 7px;}
#search-box span input[type=checkbox] { margin: 0px 7px 0px 0px; width: 15px; height: 15px; }
#search-box form { width: auto; margin: 0 0; float: left; }
#search-box form input[type=text]{ width: 380px; vertical-align: middle; font-size: 12px; padding: 2px 5px;}
#search-box form input[type=submit]{
    border-radius: 0px;
    padding: 0px 10px;
    margin-left: -5px;
    box-shadow: none;
    font-size: 12px;
    vertical-align: middle;
    height: 26px;
}
#search-box #search-info{ display: inline-block; width: 27px; height: 30px; margin: 0 0; margin-left: 5px; float: right; background:url(../img/information_small.png) center center no-repeat; }
#search-box form label { color: rgba(255,255,255,0.8); font-weight: 300; }

/*NAVIGATION*/
#navigation { background: rgb(230, 0, 0); padding: 0px 20px !important; border: 1px solid #000000; position: relative; }
#navigation ul{ padding: 0 0; }
#navigation #left-menu { display: inline-block; }
#navigation #right-menu { position: absolute; top: 0; right: 20px; }
#navigation #left-menu li, #navigation #right-menu li { display: inline-block; padding: 0px 0px; margin: 0px 0px; }
#navigation #left-menu li:hover,
#navigation #right-menu li:hover,
#navigation #left-menu li.active,
#navigation #right-menu li.active { background: rgb(199, 0, 0); }
#navigation #left-menu li:first-child, #navigation #right-menu li:first-child { /*padding-left: 0px;*/ }
#navigation a { /*text-shadow: 1px 1px 0px #333;*/ font-size: 12px; padding: 3px 15px;
    display: block; }
#navigation a:hover { color: #FFFFFF; }
#navigation #left-menu li.active a,
#navigation #right-menu li.active a{ cursor: default; text-shadow: none; }
#home i{ font-size: 14px; line-height: 15px; }
/*contact block in the header*/
#contact-detail { display: none; opacity: 0; position: absolute; left: 0px;
    padding: 15px 15px;
    background: rgba(240, 240, 240, 1);
    width: 260px;
    top: 100%;
    z-index: 101;
    cursor: default;
    border: 1px solid #C7C7C7;
    color: rgb(71, 71, 71);
}
#contact-detail a { color: inherit; text-decoration: none; padding: 0 0; }
#contact-detail a:hover { color: inherit; text-decoration: underline;}
#contact-detail address { font-style: normal; margin-top: 5px; margin-bottom: 5px; padding-left: 20px; background: url(../img/address.png) left 2px no-repeat; }
#contact-detail .contact-number { background: url(../img/telephone-icon-grey.png) top left no-repeat; padding-left: 20px; display: block; line-height: 19px; }
#contact-detail .contact-mail { background: url(../img/email-icon.png) left 3px no-repeat; padding-left: 21px; display: block; margin-top: 5px; }
#m-contact { cursor: pointer; position: relative; overflow: visible; }
#m-contact:hover #contact-detail { display: block; opacity: 1; }

/*breadcrumb*/
#breadcrumb, #toolbar { background: #f0f0f0; padding: 4px 5px 7px 5px; margin-bottom: 1px; font-size: 12px; }
#breadcrumb a{ /*color: #666;*/ text-decoration: underline; /*text-transform: capitalize;*/ }

/*CONTENT*/
#laws-list, #letters-list-container, #category-list-container, #years-list { padding-left: 20px; padding-top: 20px; }
#content{ padding: /* 20px 0px 0px 0px; */20px 15px 0px 15px; }
#content.laws { padding-top: 0px; }
#content.admin { padding-bottom: 40px; overflow: auto; }
#content .home h2 { margin-left: 15px; }
.content-splitter #main-content { display: inline-block; height: 100%; overflow: auto; }
#toolbar { margin-bottom: 20px; border-bottom: 1px solid #C7C7C7; }
#toolbar #print-file ul { list-style: none; padding: 0 0; margin: 0 0; }
#toolbar #print-file ul li { display: inline-block; border-right: 1px dotted #939393; padding-right: 10px; }
#toolbar #print-file ul li:last-child { border-right: none; margin-left: 5px; }
#toolbar #print-file ul li a#print-view{ padding-left: 20px; background: url(../img/printer-icon.png) left center no-repeat; }
#toolbar a.file-pdf { padding-left: 20px; background: url("../img/doc-pdf-icon.png") left center no-repeat; background-size: contain;}
#toolbar a.file-doc, #toolbar a.file-docx { padding-left: 20px; background: url("../img/Word-icon.png") left center no-repeat; background-size: contain;}
#toolbar a.file-png { padding-left: 20px; background: url("../img/PNG-icon.png") left center no-repeat; background-size: contain;}
#toolbar a.file-jpg, #toolbar a.file-jpeg { padding-left: 20px; background: url("../img/jpg-icon.png") left center no-repeat; background-size: contain;}
#toolbar a.file-gif { padding-left: 20px; background: url("../img/gif-icon.png") left center no-repeat; background-size: contain;}

#toolbar #print-file ul li.law-file a { display: inline-block; padding-right: 10px; }
#toolbar #print-file a{ color: #5A5A5A; text-shadow: 1px 1px 0px #fff; }
#toolbar #print-file a:hover { color: #C70000; }
#main-content #law-info, #main-content #table-content, #structure-info, #structure-content, #child-structure-info, #child-structure-content{ padding-left: 20px; }
#content h1, #content h2, #content h3 {
    /*color: #223aea;*/
    font-family: sans-serif;
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 20px;
}
#content h2 { font-size: 15px; /*color: #223aea;*/ }
#content h3 { font-size: 14px; text-transform: none; margin-bottom: 15px; /*color: #223aea;*/}
#content .laws.home h1, #content .laws.home h2, #content .laws.home h3 { color: #2b2b2b; }
#laws-list h2 { font-size: 18px; /*color: #808080;*/ text-transform: none; }
#laws-list h2 span{ color: #223aea; font-size: 12px; }
#laws-list h2 span.keyword{ color: #223aea; font-size: inherit; }
#laws-list h2 span.hl{ font-size: 18px; }
#laws-list h2 span.hl:before { content: '"'; }
#laws-list h2 span.hl:after { content: '"'; }
#content a:hover { color: red; }
.laws.home ul { padding-left: 20px; }
.laws.home ul li { margin-bottom: 5px; list-style: square inside; }
.laws.home ul li a { color: rgb(39, 58, 225); text-decoration: underline; }
.laws.home ul li a:visited { color: #03061d; }

	/*BROWSE PAGE OF LETTERS*/
    #letters-list { padding: 0 0; }
    #letters-list li, #letter-second-level li { margin-bottom: 10px; list-style: none; }
        #letters-list > li > a { text-transform: uppercase; font-weight: bold;}
	#letters-list li ul{ padding: 0 0;  }
	#letters-list li ul li { display: inline-block; margin-right: 3px; }
	#letters-list li ul li:after { content: ', '; }
	#letters-list li ul li:last-child:after { content: ''; }
    #letters-list a { color: #273AE1; text-decoration: underline; }

/*PAGE LOGIN VISTOR*/
#login-form{
    max-width: 510px;
    margin-top: 60px;
    margin-right: auto;
    margin-left: auto;
}
#login-form .wrapper{
    background-color: #EAEAEC;
    /*box-shadow: 10px 10px 0px 0px rgba(0, 0, 0, 0.2);*/
}
#login-form form{
    font-family: "Open Sans",sans-serif;
    color: #666;
    font-weight: 400;
}
#login-form h1, #signup-form h1{
    background-color: #3274FF;
    margin: 0px;
    padding: 1em 0px 1.5em 0px;
    font-weight: bold;
    text-align: center;
    box-shadow: 0px -10px 0px 0px rgba(0, 0, 0, 0.1) inset;
    color: #FFF;
    text-transform: none;
}
#login-form .field, #login-form .footer { padding: 1.5em; margin-bottom: 0px; }
#login-form form input[type="text"],  #login-form form input[type="password"] {
    font-family: "Open Sans",sans-serif;
    color: rgba(0, 0, 0, 0.5);
    display: inline-block;
    width: 60%;
    margin: 0px 0px 1em;
    padding: 0.65em 1.2em;
    font-size: 1em;
    background-color: #FFF;
    border: 0px none;
    outline: medium none;
    transition: background-color 0.3s ease-out 0s, box-shadow 0.2s ease 0s, border-color 0.2s ease 0s;
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.3) inset;
    box-sizing: border-box;
    line-height: 1.5;
}
#login-form form input[type="submit"]{
    color: #FFF;
    display: block;
    margin-left: 29%;
    border: 0px none;
    font-size: 1.2em;
    font-weight: 600;
    cursor: pointer;
    padding: 0.65em 2.0em;
    box-sizing: border-box;
    border-radius: 0px;
    margin: auto;
}
#login-form #UserEmail{ width: 55%; }
#login-form form label{
    display: inline-block;
    font-size: 15px;
    font-weight: bold;
    width: 23%;
    text-align: right;
    margin-right: 20px;
}
#forgot-password {     
    display: block;
    text-align: center;
    margin-top: 15px; }
#login-form form label.error{
    width: 100%;
    text-align: right;
    font-weight: normal;
    font-size: 100%;
}

#signup-form {
    margin: auto;
    background: #EAEAEC;
}
#signup-form .field{ padding: 20px 20px; }
.form-note{ margin-top: 10px; }
/*content layout with splitter*/
.content-splitter {
    height: 100vh;
    width: 100%;
}
.content-splitter div {
    /*overflow: auto;*/
}
.vsplitbar {
    width: 8px;
    background: #CCCCCC url(../img/vgrabber.gif) no-repeat center;
}
#side-bar-left { width: 30%; }

ul.dynatree-container { display: inline-block; }
#side-bar-left #law-tree { height: 100%; padding-right: 15px; /*padding-bottom: 15px;*/ opacity: 0; padding-left: 15px; }
.mCSB_scrollTools_vertical, .mCSB_scrollTools_horizontal { /*background: #FFF; */margin: 0 0 !important ;}

span.cap { text-transform: uppercase; }
span.indent-1 { width: 20px; display: inline-block; }
span.indent-2 { width: 40px; display: inline-block; }
span.indent-3 { width: 60px; display: inline-block; }
span.indent-4 { width: 80px; display: inline-block; }
span.indent-5 { width: 100px; display: inline-block; }
span.indent-6 { width: 120px; display: inline-block; }
span.indent-7 { width: 140px; display: inline-block; }
span.indent-8 { width: 160px; display: inline-block; }
span.indent-9 { width: 180px; display: inline-block; }
span.indent-10 { width: 200px; display: inline-block; }

a.inactive { color: #999999; cursor: default; }
a.inactive:hover { color: #999999!important; }

/*Law index page - table of content*/
#toolbar > div { display: inline-block; }
#law-info, #table-content, #child-structure-info, #child-structure-content { margin-bottom: 20px; }
#law-info h1 { /*text-transform: capitalize;*/ border-bottom: 1px solid #CCC; font-size: 18px; margin-bottom: 10px; }
#law-info span { display: block; text-align: center; font-weight: bold; font-size: 14px; }
#table-content .title { font-weight: bold; font-size: 14px; margin-bottom: 20px; display: block; color: #000; }
#table-content ul { margin-left: 20px; padding: 0 0; list-style: none; }
#table-content ul li { margin-bottom: 3px; }
#table-content ul li a {
    text-decoration: underline;
    color: #333;
}
#table-content ul li a:hover { text-decoration: underline; }

/*Law content page*/
#structure-content { margin-bottom: 20px; }

.law-navi { text-align: right; margin-bottom: 10px; padding: 3px 20px; background: #f0f0f0; }
.law-navi a { text-transform: uppercase; font-size: 11px; }
#law-navi { float: right; margin-right: 5px; color: #aaa; }
#toolbar .law-navi { float: right; }

/*page law list*/
#laws-list ul { padding: 0 0; list-style: none; }
#laws-list ul li { margin-bottom: 3px; }
#laws-list ul li a { /*text-transform: capitalize;*/ }
#laws-list ul li a:hover { text-decoration: underline; }
#laws-list ul li a:visited { color: #03061d; }

/*form style*/
form div.label{
    margin-bottom: 0;
    padding: 0;
}
form div.label label{ font-weight: bold; }
.asterik { color: red; }
/*inherit from cake generic*/
form div {
    margin-bottom: 5px;
    padding: 0 0;
}
p.error { color: red; font-family: inherit; text-shadow: none; border: none;}
.error { color: red; font-weight: normal;}
.success { color: blue; text-shadow: none; border: none;}
.success, .message, .cake-error, .cake-debug, .notice, p.error, .error-message {border: none;text-shadow: none; border-radius: 0; }

ul#search-result li{
    margin-bottom: 0px;
    padding: 4px 10px;
    background: #fafafa;
    margin-right: 20px;
}
ul#search-result li:nth-child(even) {
    background: #eaeaea;
}
ul#search-result li.law_heading { padding-left: 0px; font-weight: bold; border-top: 1px solid #9a9999; }
ul#search-result li .hl_content{
    padding-left: 30px;
    color: #5d5b5b;
    margin-bottom: 10px;
}
ul#search-result li.heading a:visited{ color: #3e4794; }
.search-heading-panel{
    margin-top: -20px;
    margin-left: -20px;
    padding: 20px;
    /*background: #f7f7f7;*/
    /*margin-bottom: 20px;*/
    padding-bottom: 15px;
}
.search-heading{ margin-top: -10px; }
.search-heading b{ color: #223aea; font-weight: normal;}
.paging { margin-bottom: 20px; border-top: 1px solid #efefef; padding-top: 10px;}
.highlight{ font-weight: bold; color: red;}

.menu_lv1 { display: none; position: absolute; top: 20px; left: 0px; }
.menu_lv1 a { white-space: nowrap; }
#navigation ul li:hover ul{ display: block; }
#navigation > ul > li { position: relative; }
.sidebar { width: 20%; }
.sidebar .left-sidebar{ float: left; }
.sidebar .right-sidebar { float: right; }
#stat-list { list-style: none; padding: 0 0;}
#stat-list li{list-style: none;}
.label {
    display: inline;
    padding: .2em .6em .3em;
    font-size: 85%;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: .25em;
}
.label-red{ color: red; }
ul#home-law-list li a { text-decoration: none; font-weight: 300; }
#home-law-list li { list-style: square; }
.col-half {
    width: 45%;
    display: inline-block;
    clear: none;
    margin: 0 1%;
}
.full-width{ width: 100%; }
label.title {font-weight: bold;}
#signup-form h3 {color: #2d68e5;}
select{ border: 1px solid #d2d2d4;
    background: white;
    height: 30px; }
form .required label.error:after{ content: ''; }
p.error, .error-message {
    clear: both;
    color: #ff0100;
    text-align: left;
    font-weight: normal;
    padding: 0 0;
}
#flashMessage.warning{ background: orange; color: black; }
#flashMessage.danger{ background: red; color: black; }
#flashMessage.info{ color: black; }
#flashMessage.success{ background: greenyellow; color: black; }
#flashMessage{
    background: #eaeaec;
    margin-top: -20px;
    margin-left: -20px;
    margin-right: -15px;
    color: #464545;
}
#flashMessage.success{
    background: #26b515;
}
#flashMessage.cake-error, #flashMessage.error-message{ color: #e60100; }
/*.sidebar-left{ border-right: 1px solid #dfdfdf; }*/
.sidebar-left ul li a{ text-decoration: none !important; }
.sidebar-left ul li.active a{ font-weight: bold; color: black; text-decoration: none;}
.list-group .list-group-item{ margin-bottom: 0; }
.list-group .list-group-item a{ color: #292929; display: block;}
.list-group .list-group-item.active a{ color: white; font-weight: 600; }
.tab-content{ border: 1px solid #dde2e6; margin-top: -1px; padding: 20px; }
#content h3.current-plan{ font-size: 20px; font-weight: 300; }
#content h3.current-plan .plan-title{ font-weight: 500; }
#plan-selector label{
    width: 100px;
    text-align: center;
    white-space: normal;
}
.btn{ font-weight: 300; font-size: 0.9rem; }
.plan_price{
    display: block;
    border-top: 1px solid #bfbdbd;
    margin-top: 5px;
    padding: 5px;
    font-weight: bold;
    color: #2d2d2d;
}
.nav-tabs .nav-link.active{ font-weight: bold; }
/*Form input*/
.input-inline label{ display: inline-block; }
#search-form .input-title{ width: 100px; }
input[type=checkbox]{ margin-top: 0 0; }
#search-form .input-inline{ margin-bottom: 10px; }
.form-control { /*height: auto; */font-size: unset; border-radius: unset;}
#search-form #issued_date{ width: 150px; }
#search-form #institution{ width: 250px; }
#search-form #language{ width: 100px; }
.form-group{ margin: 0 5px; }

#help-lnk + .dropdown-menu{
    border-radius: 0;
    background-color: rgba(240, 240, 240, 1);
    top: 95%;
}
#help-lnk + .dropdown-menu li{
    width: 100%;
}
#help-lnk + .dropdown-menu li a{
    color: #003d4c
}
#help-lnk + .dropdown-menu li a:hover{
    color: #FFF;
}










