/* ******************* RESET ***************** */
html {
	color: #000;
}

html,
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
button,
textarea,
p,
th,
td 
{
	margin: 0;
	padding: 0;
}

table 
{
	border-collapse: collapse;
	border-spacing: 0;
}

fieldset, img, div, table 
{
	border: 0;
}

caption, th, td, div, a, table 
{
	text-align: left;
}

td
{
	vertical-align: top;
}

input,
button,
textarea,
select,
optgroup,
option 
{
	font-family: inherit;
	font-size: inherit;
	font-style: inherit;
	font-weight: inherit;
}

h1, h2, h3, h4, h5, h6
{
	font-weight: bold;
}

h1	
{
	font-size: 2em;
	/*margin: 0.67em 0;*/
}

h2	
{ 
	font-size: 1.5em;
	/*margin: 0.75em 0;*/
}

h3	
{ 
	font-size: 1.17em;
	/*margin: 0.83em 0; */
}

h4
{ 
	font-size: 1em;
	/*margin: 1.12em 0;*/
}

h5	
{
	font-size: 0.83em;
	/*margin: 1.5em 0; */
}

h6	
{
	font-size: 0.6em;
	/*margin: 1.67em 0;*/ 
}

/********************* COMMON STYLES *****************/

body 
{
	background: url(images/bg.jpg); 
	font-family: Arial, Helvetica, Sans-Serif;
	color: #000; 
	font-size: 12px;	
	text-align: center;
}

a
{
	color: #333;
}

a:hover
{
	text-decoration: none;
}

div
{
	text-align: left;
}

.clear
{
	clear: both;
}

textarea:focus, input[type="text"]:focus, input[type="password"]:focus, select:focus 
{
	/*
	-moz-outline-radius-bottomleft: 6px;
	-moz-outline-radius-bottomright: 6px;
	-moz-outline-radius-topleft: 6px;
	-moz-outline-radius-topright: 6px;
	*/
	border-color: #888;
	outline: 2px solid #c9e1f9;
}

textarea, input[type="text"], input[type="password"], select 
{
	/*
	-moz-background-clip: border;
	-moz-background-inline-policy: continuous;
	-moz-background-origin: padding;
	-moz-border-radius-bottomleft: 4px;
	-moz-border-radius-bottomright: 4px;
	-moz-border-radius-topleft: 4px;
	-moz-border-radius-topright: 4px;
	*/
	border-color: #ccc;
	border: 1px solid #ccc;
	padding: 2px;
}

textarea:hover, input[type="text"]:hover, input[type="password"]:hover, select:hover 
{ 
	border-color: #aaa; 
}

#header1, #header2, #header_bottom, .language a, #footer_top, .news_date_index
{
    background-image: url(images/main_sprite.jpg);
    background-repeat: no-repeat;
}

#header_holder1, #header_left, #header_right, #footer_middle, #footer_left, #footer_right, .frame, .profile_frame
{
    background-image: url(images/main_png_sprite.png);
    background-repeat: no-repeat;
}

/* *************** HEADER *******************/

#header
{
	width: 1055px;
	height: 262px;
	margin: 0 auto;
}

#header_holder1
{
	clear: both;
	height: 262px;
	text-align: center;
	background-position: 20% -331px;
}

#header_holder2
{
	clear: both;
	height: 262px;
	text-align: center;
    background: url(images/wallpaper2.png) no-repeat bottom right;
	/*background-position: 200% -593px;*/
}

#header_bottom
{
	width: 1055px;
	height: 72px;
	margin: 0 auto;
	background-position: left -265px;
}

#header_left
{
	float: left; 
	width: 36px; 
	height: 262px; 
	background-position: 4px top;
}

#header_right
{
	float: left; 
	width: 36px; 
	height: 262px; 
	background-position: -32px top;
}

#header1
{
	float: left; 
	width: 320px; 
	height: 262px; 
	background-position: left top;
}

#header2
{
	float: left; 
	width: 663px; 
	height: 262px; 
	background-position: -320px top;
}

#logo_link
{
	display: block;
	float: left;
	width: 135px;
	height: 130px;
}

#top_buttons_holder
{
	float: right;
	height: 262px;
	width: 100px;
}

#top_buttons
{
	clear: both;
	height: 210px;
	padding-top: 10px;
}

#top_buttons a
{
    display: block;
    width: 28px;
    height: 26px;
    margin-left: 5px;
    float: left;
}

#languages
{
	clear: both;
	padding-right: 10px;
}

.language
{
	clear: both;
	height: 16px;
	text-align: right;
}

.flag_eng
{
    display: block;
    width: 28px;
    height: 13px;
    background-position: -983px 0px;
}

.flag_rus
{
    display: block;
    width: 28px;
    height: 14px;
    background-position: -983px -13px;
}

.top_menu_holder
{
	float: left;
	height: 242px;
	padding: 20px 0px 0 18px;
	text-align: left;
}

.top_menu_item
{
	display: block;
	font-size: 14px;
	font-weight: bold;
	text-align: left;
}

.top_submenu_item
{
	display: block;
	font-size: 14px;
	font-weight: bold;
	text-align: left;
	padding-top: 10px;
	text-decoration: none;
}

.top_submenu_item:hover
{
	text-decoration: underline;
}

/* *************** CONTENT *******************/
#wrapper
{
	height: auto;
	background-color: #e8e8e8;
	text-align: center;
}

#content
{
	clear: both;
	width: 975px;
	background: url(images/middle_bg.jpg) repeat-y left top;
	margin: 0 auto;
	overflow: auto;
	padding: 0 40px;
}

/* *************** FOOTER *******************/

#footer_holder1
{
	clear: both;
	height: 64px;
	text-align: center;
}

#footer_holder2
{
	clear: both;
	height: 64px;
	text-align: center;
}

#footer
{
	width: 1055px;
	height: 58px;
	margin: 0 auto;
	clear: both;
}

#footer_top
{
	width: 1055px;
	height: 56px;
	margin: 0 auto;
	background-position: left -339px;
}

.footer_menu_item
{
	float: left;
	display: block;
	padding: 20px 15px 0px 15px;
	font-weight: bold;
}

#footer_left
{
	float: left; 
	width: 36px; 
	height: 64px; 
	background-position: -64px top;
}

#footer_right
{
	float: left; 
	width: 36px; 
	height: 64px; 
	background-position: -68px -74px;
}

#footer_middle
{
	float: left; 
	padding-left: 140px;
	padding-right: 190px;
	width: 653px; 
	height: 64px; 
	background-position: 0px -265px;
	text-align: left;
}

#copyright
{
	float: right;
	padding-top: 20px;
	font-weight: bold;
	width: 120px;
}

/* **************************** FRESH ******************** */
.frame
{
	clear: both;
	width: 206px;
	height: 250px;
	background-position: -100px top;
}

.fresh_image
{
	clear: both;
	height: 173px;
	background-repeat: no-repeat;
	background-position: 21px 11px;
}

.fresh_link
{
	display: block;
	padding-top: 15px;
	padding-left: 20px;
	float: left;
}

/* **************************** NEWS ******************** */

.news_block_index
{
	clear: both;
	overflow: auto;
	padding-bottom: 10px;
}

.news_date_index
{
	clear: both;
    width: 78px;
	height: 21px;
	line-height: 21px;
	background-position: -983px -27px;
	font-weight: bold;
	padding-left: 15px;
}

.news_separator_index
{
	clear: both;
	height: 10px;
}

.news_brief_index
{
	padding-top: 10px;
	padding-left: 0px;
	font-weight: bold;
}

a.readmore_link
{
	color: #106781;
	font-weight: bold;
}

#news_section_image
{
	float: left;
	height: 250px;
	width: 350px;
	background: url(images/news.png) no-repeat center top;
}

.new_title
{
	font-size: 20px;
	clear: both;
}

.new_date
{
	clear: both;
	color: #336699;
	font-size: 18px;	
	font-weight: bold;
	padding-top: 5px;
}

.new_text
{
	clear: both;
}

.new_separator
{
	clear: both;
	height: 20px;
}

/* **************************** INDEX PAGE *************** */
#we_index
{
	float: left; 
	width: 470px; 
	padding: 40px 20px 0 0;
	background-repeat: no-repeat;
}

#fresh_headline_index
{
	float: left; 
	width: 230px; 
	height: 42px; 
	padding-left: 540px;
	padding-top: 30px; 
	font-size: 16px; 
	font-weight: bold;
}

#fresh_index
{
	float: left; 
	width: 240px;
}

#news_headline_index
{
	float: left; 
	width: 200px; 
	height: 42px; 
	padding-top: 30px; 
	font-size: 16px; 
	font-weight: bold;
}

#news_index
{
	float: left; 
	width: 200px;
}

#testimonials_headline_index
{
	float: left; 
	width: 200px; 
	height: 42px; 
	padding-top: 30px; 
	font-size: 16px; 
	font-weight: bold;
}

#testimonials_index
{
	float: left; 
	width: 200px;
}

/* **************************** ABOUT PAGE *************** */
#about_section_image
{
	float: left;
	height: 350px;
	width: 350px;
	background: url(images/about_us.png) no-repeat center top;
}

.profiles
{
	float: left;
	padding-top: 20px;
	width: 100%;
}

.profile_column
{
	float: left;
	width: 50%;
}

.profile_frame
{
	clear: both;
	width: 206px;
	height: 250px;
	background-position: -100px top;
}

.profile_avatar
{
	clear: both;
	height: 173px;
	background-repeat: no-repeat;
	background-position: 21px 11px;
}

.profile_nickname
{
	clear: both;
	padding-top: 15px;
	padding-left: 20px;
	font-weight: bold;
}

.profile_info
{
	clear: both;
	padding-top: 0px;
	padding-left: 20px;
}

.profile_info_header
{
	font-weight: bold;
}

/* **************************** CONTACTS PAGE *************** */
#contacts_section_image
{
	float: left;
	height: 350px;
	width: 350px;
	background: url(images/contacts.png) no-repeat center top;
}

.contacts_type
{
	clear: both;
	padding-top: 10px;
	height: 25px;
	font-weight: bold;
	font-size: 14px;
}

.contacts_item
{
	clear: both; 
	height: 20px; 
	line-height: 20px; 
	padding-left: 20px;
}

.skype
{
	background: url(images/skype.png) no-repeat left center;
}

.contacts_icq
{
	background: url(images/icq.png) no-repeat left center;
}

.contacts_email
{
	background: url(images/email.png) no-repeat left center;
}

/* **************************** PORTFOLIO PAGE *************** */
#portfolio_section_image
{
	float: left;
	height: 300px;
	width: 200px;
	background: url(images/portfolio_brief.png) no-repeat center top;
}

.pf_frame_small
{
	float: left; 
	padding: 10px; 
	width: 246px; 
	height: 200px; 
	border: 1px solid #ccc;
	background-color: #fff;
}

.pf_small_image
{
	clear: both;
	width: 246px;
	height: 162px;
	border: 1px solid #ccc;
}

.pf_small_spacer
{
	float: left; 
	width: 80px; 
	height: 200px; 
}

.pf_small_spacer_vert
{
	clear: both; 
	height: 20px; 
}

.pf_small_cat
{
	clear: both; 
	padding-top: 5px;
}

.pf_small_title
{
	clear: both; 
	padding-top: 5px;
}

.portfolio_left
{
	float: left;
	padding-left: 10px;
	width: 680px;
	overflow: auto;
}

.pf_frame_big
{
	clear: both;
	padding: 10px; 
	width: 650px; 
	border: 1px solid #ccc;
	background-color: #fff;
	margin: 0 auto;
}

.pf_big_spacer
{
	clear: both;
	height: 30px; 
}

.pf_big_image
{
	clear: both;
	width: 650px;
	border: 1px solid #ccc;
}

.pf_big_info
{
	clear: both;
	padding-left: 10px;
	overflow: auto;
	padding-top: 10px;
}

.pf_big_title
{
	clear: both; 
	font-size: 14px;
	font-weight: bold;
}

.pf_big_type
{
	clear: both; 
	padding-top: 5px;
	font-size: 12px;
}

.pf_big_date
{
	clear: both; 
	padding-top: 5px;
	font-size: 13px;
}

.pf_big_desc
{
	clear: both; 
	padding-top: 20px;
	font-size: 12px;
}

.pf_big_url
{
	clear: both; 
	padding-top: 5px;
	font-size: 13px;
}

.portfolio_pages
{
	clear: both;
	width: 200px;
	height: 30px;
	padding-top: 20px;
	margin-left: 210px;
}

.portfolio_detailed_pages
{
	clear: both;
	width: 200px;
	height: 30px;
	padding-top: 20px;
	margin-left: 235px;
}

#portfolio_prev_page
{
	display: block;
	float: left;
	width: 24px;
	height: 21px;
	background: url(images/page_prev.png) no-repeat;
}

#portfolio_page_label
{
	float: left;
	width: 150px;
	height: 21px;
	color: #666;
	font-size: 12px;
	font-weight: bold;
	text-align: center;
	line-height: 21px;
}

#portfolio_next_page
{
	display: block;
	float: right;
	width: 24px;
	height: 21px;
	background: url(images/page_next.png) no-repeat;
}

#flash_popup
{
	display: none; 
	padding: 10px; 
	border: 1px solid #ccc; 
	background-color: #fff;
	margin: 0 auto;
    overflow: hidden;
}

.close_button
{
	float: right; 
	height: 20px; 
	width: 16px;
	cursor: pointer;
	background: url(images/close.png) no-repeat top right;
	
}

#flash_iframe
{
    overflow: hidden;
    border: 0;
    visibility: hidden;
}

#pf_show_flash_link
{
    cursor: pointer;
}

/* **************************** SERVICES PAGE *************** */
#services_section_image
{
	float: left;
	height: 350px;
	width: 350px;
	background: url(images/service.png) no-repeat center top;
}

.services_list
{
    padding-top: 10px;
    padding-left: 15px;
}

/* **************************** TESTIMONIALS PAGE *************** */
.leave_testimonial
{
	clear: both;
	margin-bottom: 0px;
}

#leave_testimonial_form
{
	display: none;
}

#leave_testimonial_table td
{
    padding-top: 5px;
} 

#testimonial_pages
{
	clear: both;
	padding-top: 20px;
}

.testimonial
{
	padding-top: 20px;
}

.testimonial_author
{
	font-weight: bold;
}

#leave_testimonial_link
{
    text-decoration: underline;
    cursor: pointer;
}

#leave_testimonial_link:hover
{
    text-decoration: none;
}

/* **************************** SITEMAP PAGE *************** */
#sitemap_section_image
{
	float: left;
	height: 550px;
	width: 350px;
	background: url(images/sitemap.png) no-repeat center top;
}

.sitemap_list
{
    padding-left: 15px;
    list-style-type: disc;
}

.sitemap_list ul
{
    padding-left: 15px;
    list-style-type: disc;
}

.sitemap_list ul li
{
	padding: 2px 0;
}

.sitemap_list ul ul
{
    padding-left: 15px;
    list-style-type: disc;
}

/* **************************** MISC ******************** */

.inner_text
{
	float: left;
	padding-left: 10px;
	width: 550px;
}

.section_title
{
	clear: left;
	height: 40px;
	background-repeat: no-repeat;
	background-position: 10px top;
}

#breadcrumbs
{
	clear: left;
	height: 40px;
	font-size: 16px;
	font-weight: bold;
	color: #666;
	padding-left: 10px;
}

#breadcrumbs a
{
	font-size: 16px;
	font-weight: bold;
	color: #666;
}

.spacer20px
{
	clear: both;
	height: 20px;
	overflow: hidden;
}

.spacer10px
{
	clear: both;
	height: 10px;
	overflow: hidden;
}

.spacer5px
{
	clear: both;
	height: 5px;
	overflow: hidden;
}

.validator_block
{
    clear: both;
    display: none;
    /*background: url(images/validation_advice.gif) no-repeat left 10px;*/
    /*padding-left: 20px;*/
    padding-top: 5px;
    padding-right: 0px;
    color: #f00;
    font-size: 12px;
    font-weight: normal;
    vertical-align: top;
}

.validator_highlight
{
    border: 1px dashed #f00 !important;
    background-color: #FAEBE7 !important;
}