@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;600;700&display=swap');

@font-face{
    src:url(/themes/custom/ElChPr/fonts/terminator_cyr_v4.ttf);
    font-family: terminator;
}


:root {
    --ecp_black : #202020;
    --ecp_black_hover : #888888;
    --ecp_blue : #3A4F9D;
    --ecp_yellow : #FBC000;
}

*:focus-visible,
*:focus {
    outline: 0 !important;
}

html {
    font-family: 'Roboto', sans-serif;
    color: var(--ecp_black);
}

html, body {
  overflow-x:hidden
}

body {
    min-height: 100vh;
}

.dialog-off-canvas-main-canvas {
    overflow: hidden;
}

.layout-container {
    margin-bottom: 4rem;
}

.container {
    width: 100%;
    max-width: 543px;
    margin: 0 auto;
  }


h1 {
    font-size: 16px;
    font-weight: 700;
    line-height: 18.75px;
    text-align: center;
    text-decoration-line: underline;
}

h2 {
    font-size: 14px;
    line-height: 16px;
    text-align: center;
    color: var(--ecp_black);
}

h3 {
font-weight: 500;
font-size: 10px;
line-height: 12px;
text-align: center;
color: var(--ecp_black);
}

.text-formatted h2 {
	text-align: inherit;
}

.text-formatted h3 {
	font-size: 2rem;
	text-align: inherit;
    line-height: 1.25;
}


header {
    background: var(--ecp_blue);
    max-width: 1280px;
    margin: 0 auto;
}

.region-header {
    display: flex;
    justify-content: space-between;
    height: 40px;
}




#block-elchpr-site-branding {
    display: flex;
    padding: 6px 8px;
    justify-content: flex-start;
    position: relative;
    flex: 1 1 auto;
}

.site-logo {
    display: block;
    margin-right: 0.5rem;
    align-self: center;
    width: clamp(2rem, 4vw, 5rem);
}

.site-logo img {
    width: 100%;
    height: 100%;
}

.site-name {
    display: block;
    align-self: center;
    width: 100%;
}

    .site-name a {
    font-family: terminator;
    font-size: clamp(9px, 2vw, 24px);
	color: #ffffff;
	/* line-height: 13.4px; */
	text-decoration: none;
}

.decor {
    position: absolute;
    z-index: 0;
    display: none;
}



#block-pereklyuchatelyazyka {
    display: flex;
    flex: 0 0 35px;
}

.block-language .links {
    list-style: none;
    margin: 0;
    padding: 0;
}

.block-language .links {
    list-style: none;
    padding-right: 0.5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    line-height: 1;
}

.language-link {
    color: #eee;
    text-decoration: none;
}

ul.links a.is-active {
    visibility: hidden;
}

#block-header-contacts {
    display: none;
}

#block-elchpr-main-menu {
    width: 1200px;
    margin: 0 auto;
}

#block-elchpr-main-menu .menu {
    display: flex;
    gap: 5rem;
    justify-content: center;
    background: #CDCFD6;
    font-weight: bold;
    line-height: 3rem;
    border-radius: 1rem;
    display: none;
}

/* --------------------------- Cheesburger menu --------------------------------------------------------- */

.block-cheeseburgermenu-container {
    width: 200px;
    left: unset;
    right: 0;
    transform: translateX(100%);
}

.block-cheeseburgermenu-container--is-open {
	transform: translateX(0);
	z-index: 201;
}

.cheeseburger-menu__side-trigger svg {
	background: var(--ecp_blue);
	margin-right: 2rem;
}

/*-------------------------------------------------------------------- */

.page-title {
	color: var(--ecp_blue);
    text-decoration: none;
}

main {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.node--type-usluga.node--view-mode-full {
    max-width: 1280px;
    margin: 0 auto;
    font-size: 10px;
    line-height: 11.72px;
}

.view-servicez .service {
    display: flex;
    border: 1px solid var(--ecp_yellow);
    margin-bottom: 1.5rem;
    border-radius: 5px;
}

-list-title h2 {
    color: var(--ecp_blue);
}

.services-page.view-services h2 a {
    color: var(--ecp_blue);
    text-decoration: none;
}

.view-our-services img {
    max-width: 120px;
}

.services-page .view-service-child ul,
.services-page .view-service-child h3 {
    text-align: left;
    font-size: 10px;
    line-height: 12px;
}

.services-page .view-service-child a {
	display: block;
    text-decoration: none;
    color: var(--ecp_black);
}

.services-page .view-service-child a:hover {
	text-decoration: none;
    color: var(--ecp_black_hover);
}

.view-servicez.views-field-field-term-image,
.field--name-field-pictures {
    flex: 0 1 25%;
}

.service-term-title {
	font-size: 0.75rem;
	line-height: 1.175;
    font-weight: 500;
}

.service-term-title a{
    text-decoration:none;
    color: var(--ecp_black);
}

.service-term-title a:hover,
.service-term-title a:focus{
    color: var(--ecp_blue);
}



.service .views-field.views-field-nothing,
.field--name-field-body {
    flex: 1 1 75%;
    padding: 1rem;
}


.items-cell {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 3rem;
}

.items-cell .views-field-name h2 {
    margin: 0;
}
.items-cell .views-field-name {
    flex: 1 1 100%;
    text-align: center;
    border-bottom: 3px solid var(--ecp_yellow);
    margin-bottom: 2rem;
}

.items-cell .views-field-name::after {
    content: '.';
    background: var(--ecp_yellow);
    width: 85%;
    display: inline-block;
    position: relative;
    top: 18px;
    color: var(--ecp_yellow);
    border-radius: 0 0px 5px 5px;
}




.items-cell .views-field-description__value {
    flex: 1 1 60%;
    padding: 0 1rem;
}


.node.node--type-news.node--view-mode-full {
    max-width: 1280px;
    margin: 0 auto;
    padding: 1rem;
}

.block-block-content {
    max-width: 1280px;
    margin: 0 auto;
    padding: 1rem;
}



/*----------------------------- IFRAME BLOCK -------------------------------- */

#block-testiframe {
    display: grid;
    position: relative;
    grid-template-rows: 1fr auto 1fr;
    gap: 1rem;
}
/*  ------------------  порядок в ГРИДе ----------------------*/
.field.field--name-field-block-form {
    /* grid-area: 1 / 1 / 2 / 2; */
    grid-area: 4 / 1 / 5 / 2;
}

.field.field--name-field-block-file {
    /* grid-area: 4 / 1 / 5 / 2; */
    grid-area: 1 / 1 / 2 / 2;
}

.field.field--name-field-block-iframe {
    grid-area: 2 / 1 / 3 / 2;
}


.field.field--name-field-achievements {
    grid-area: 3 / 1 / 4 / 2;
}

/*  ------------------  порядок в ГРИДе КОНЕЦ ----------------------*/

.field--name-field-iframe-subtitle {
    display: none;
}

.myiframe {
    height: 54vw;
}

.field--name-field-achievements {
    display: flex;
    justify-content: space-around;
    align-items: baseline;
    gap: 0.5rem;
    text-shadow: 0px 6px 6px rgba(0, 0, 0, 0.25);
}

.field--name-field-achievements .field__item {
	border-bottom: 2px solid var(--ecp_black);
	width: 100%;
}

.double-field-first {
    color: var(--ecp_blue);
    font-size: 14px;
    line-height: 11.72px;
    font-weight: 700;
    padding-right: 4px;
}

.double-field-second {
	font-size: clamp(8px,2vw,2.085vw);
	font-weight: 500;
	line-height: 9.72px;
	margin-left: -4px;
}

/* ------------END OF----------- IFRAME BLOCK -------------------------------- */


.btn,
.field--name-field-blockk-file {
    display: inline-block;
    padding: 1rem;
    border-radius: 5px;
    margin-bottom: 1.5rem;
    color: white;
    text-decoration: none;

}

.btn-info {
    background: #4e84ea;
}

.field--name-field-blockk-file {
    background: #1d991d;
    color: white;
    text-decoration: none;
}

.field--name-field-blockk-file a {
    color: white;
    text-decoration: none;
}

#block-knopkizakaziskachat {
    display: flex;
    justify-content: space-evenly;
}

#block-okompanii {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
}

#block-okompanii .field--name-field-text-bottom,
.more-link {
	text-align: center;
	font-size: 0.75rem;
	line-height: 1.25;
	font-weight: 500;
    padding: 1rem 0;
}

#block-okompanii .field--name-field-text-bottom {
	flex: 1 1 100%;
}

.field--name-field-picture {
    flex: 1 1 220px;
    text-align: center;
}

#block-okompanii .field--name-field-picture img {
    width: 129px;
    height: 192px;
}

#block-okompanii .field--name-body {
    flex: 1 1 316px;
    text-align: center;
    font-weight: 500;
    font-size: 10px;
    color: var(--ecp_black);
}

#block-okompanii a,
#block-okompanii a:visited {
	color: var(--ecp_black);
}

#block-okompanii a:hover {
	color: var(--ecp_blue);
}

.view-news .view-content {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
}

.news-item {
    flex: 1 1 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    /* padding: 0 1rem; */
}

.field--name-field-news-photos {
	float: left;
	padding-right: 1rem;
}

.views-field-field-news-photos {
	text-align: center;
}

.view-display-id-news img {
    border-radius: 8px;
    width: 100%;
    height: 100%;
}

.view-id-news img {
	width: 100%;
}

.view-display-id-news .views-field-title {
	padding: 0.5rem 0;
	border-bottom: 1px solid var(--ecp_black);
    text-align: left;
}

.view-display-id-news h3 a {
    font-weight: 500;
    font-size: 12px;
    line-height: 14px;
    text-decoration: none;
    color: var(--ecp_black);
}

.view-display-id-news .views-field-created {
    padding: 0.25rem 0;
    text-align: left;
    color: var(--ecp_blue);
    font-size: 10px;
    line-height: 12px;
    font-weight: 300;
}

.view-display-id-news .views-field-body {
    font-size: 12px;
    line-height: 14px;
    color: var(--ecp_black);
}

.more-link a,
.more-link a:visited {
    color: var(--ecp_black);
}

.more-link a:hover {
    color: var(--ecp_blue);
}

/* -------------------------Параграфы Paragraphs -----------------------------------------------*/


.paragraph--type--paragraf-dlya-bazovoy {
	display: flex;
	flex-wrap: wrap;
    padding: 0 1rem;
}

.paragraph--type--paragraf-dlya-bazovoy h2 {
	margin: 0;
    flex-basis: 100%;
}

.field--name-field-text-full-width {
	padding: 1rem 0;
}

.field--name-field-imgs-para {
	flex: 1 1 20%;
	text-align: center;
}

.field--name-field-text-with-imgs {
	flex: 1 1 67%;
}

/* ----------------------- Partners         Партнеры ---------------------------------------------------- */

#block-views-block-partners-logos-block-partners .views-row {
	display: flex;
	justify-content: center;
	align-items: center;
    flex: 1 1 44%;
}

.block.view-partners-logos .view-content {
	display: flex;
	flex-flow: row wrap;
	justify-content: space-around;
	gap: 1rem;
}

.page.view-partners-logos .view-content {
    display: flex;
    flex-wrap: wrap;
}

.media--view-mode-media-partners .field__item {
	text-align: center;
}

.page .view-partners-logos .views-row {
    flex: 1 1 44%;
    margin-bottom: 3rem;
    padding: 0 1rem;
    flex-direction: column;
    display: flex;
    justify-content: start;
}


.page.view-partners-logos .views-row {
    padding: 1rem;
    display: flex;
    flex-flow: column nowrap;
}

.page .views-row .media--view-mode-media-partners {
	flex: 1 1 107px;
}
.page .field--name-field-media-image-1 {
	height: 107px;
	display: flex;
	justify-content: center;
	align-items: end;
}



.page.view-partners-logos p {
	flex: 1 1 90%;
}


/*------------------------------FOOTER ПОДВАЛ ------------------------- */

footer {
    padding: 0 1rem;
}

.region.region-footer {
    display: flex;
    flex-wrap: wrap;
    border-width: 1px 0 1px 0;
    border-style: solid;
    border-color: var(--ecp_blue);
    margin-bottom: 8rem;
}

#block-menu-footer {
    flex: 1 1 auto;
}

#block-menu-footer ul.menu {
    margin: 0;
    padding: 0;
    list-style: none outside;
    text-align: center;
}

#block-menu-footer .menu-item {
    margin: 0;
    padding-top: 1em;
    min-width: 120px;
}

#block-icons-footer {
	margin: 0;
	padding: 0;
	flex: 0 0 35px;
	text-align: center;
}

.soc_icon_img img {
	width: 2rem;
	height: 2rem;
	margin-bottom: 1.75rem;
}

#block-menu-footer .menu-item a,
#block-menu-footer .menu-item a:visited {
	color: var(--ecp_black);
	text-decoration: none;
}

#block-menu-footer .menu-item a:hover,
#block-menu-footer .menu-item a:focus {
	color: var(--ecp_blue);
}

#block-menu-footer .menu-item--expanded a {
	text-decoration: underline;
	display: block;
	text-align: center;
}

#block-menu-footer .menu .menu .menu-item a {
	text-align: left;
    text-decoration: none;
}



#block-menu-footer .menu-item--expanded {
    list-style: none;
}

#block-menu-footer .menu-item li {
    display: none;
}

#block-footer-contacts {
    flex: 1 0 100%;
    padding: 0;
}


#block-footer-contacts .field--name-body {
    display: flex;
    justify-content: space-around;
    text-align: center;
    font-size: 10px;
    line-height: 12px;
    color: var(--ecp_black);
    padding: 0;
    align-items: end;
}

#block-footer-contacts .field--name-body p:nth-child(n+2) {
    display: none;
}

#block-footer-contacts .field--name-body::after {
    display: none;
}

/*-------------------------------------- VIEWES ----------------------------------- */

.view-services .view-content {
    display: flex;
    flex-wrap: wrap;
    padding: 0;
}

.item {
    flex: 1 1 220px;
    justify-content: center;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    border-top: 1px solid var(--ecp_blue);
    border-bottom: 1px solid var(--ecp_blue);
    margin-bottom: 2rem;
    text-align: center;
}


/*-------END OF  VIEWES ----------------------------------- */




/*         Didviders --------------------------------*/


.divider--yellow.first-divider {
    display: none;
}

.divider--yellow {
    display: block;
    width: 90%;
    margin: 0 auto;
    margin-bottom: 2rem;
}

.inner.line.bottom {
    border-width: 0px 3px 3px 3px;
    top: 11px;
}

.inner.line.filled.bottom {
    border-width: 0px 3px 0px 3px;
    top: 11px;
    background: var(--ecp_yellow);
    height: 8px;
}

.yellow_lines_title {
    flex: 1 1 100%;
    margin-bottom: 2rem;
}

.our_services .page-title {
	padding: .5rem;
}

.our_services .outter.top {
	top: 1rem;
	margin-top: 0;
}

.node--type-usluga.node--view-mode-teaser {
	padding: 0 1rem;
}

.node--type-usluga.node--view-mode-teaser h2 {
    margin: 0;
}

.node--type-usluga.node--view-mode-teaser h2 a {
    text-decoration: none;
    color: var(--ecp_black);
}

.outter,
.inner {
    display: block;
    max-width: 543px;
    margin: 0 auto;
    border-bottom: 3px solid var(--ecp_yellow);
    position: relative;
    z-index: -1;
}

.field--name-field-divider {
	display: block;
	grid-area: 1 / 1 / 2 / 2;
	margin-top: 2rem;
}

.outter.top {
    top: 6px;
    width: 80%;

}

.inner.top {
    background: white;
    height: 8px;
    margin: 0 auto;
    border-width: 3px 3px 0px 3px;
    border-color: var(--ecp_yellow);
    border-style: solid;
    border-radius: 6px 6px 0 0;
    position: relative;
    top: 3px;
    width: 80%;
}

.yellow_lines_title h2 {
    font-weight: 600;
    margin: 0;
    padding: 3px 0 6px 0;
}

.field--name-field-block-divider {
    display: none;
}

.outter.bottom {
    top: -23px;
    width: 80%;
}

.inner.bottom {
    background: white;
    height: 8px;
    margin: 0 auto;
    border-width: 0px 3px 8px 3px;
    border-color: var(--ecp_yellow);
    border-style: solid;
    border-radius: 0 0 6px 6px;
    position: relative;
    top: 16px;
    width: 80%;
}

/* .field--name-field-news-photos .field__item:not(:first-child) {
    display: none;
} */

.field--name-field-service-photos {
    text-align: center;
}

.ec-toggle-link {
	color: var(--ecp_yellow);
	padding: 1rem 0;
	display: block;
    text-align: center;
}

.ec-toggle-link.ecf-open:hover,
.ec-toggle-link.ecf-close:hover {
	color:var(--ecp_blue);
}
.thumbs-slider img {
    width: auto;
}
.page-node-type-news #tns1 > .tns-item {
    text-align: center;
    margin: auto;
    display: block;
}
.page-node-type-news .thumbs-slider li {
    width: auto;
}


/*---------- start in 2025 NEW ----------------- */

.field--name-field-kartinka.field__items {
    display: flex;
    justify-content: space-around;
}

.field--name-field-kartinka .field__item {
    flex: 0 1 220px;
}
.paragraph--type--prosto-tekst h2,
.paragraph--type--prosto-tekst h3,
.field--name-field-forma.field__item {
    text-align: center;
}

.node.node--type-stranica-s-paragrafami.node--view-mode-full {
    font-size: 1.25em;
}


.my-view-row {
    display: flex;
    margin-bottom: 2rem;
    align-items: center;
}

.employ {
    flex: 1 1 auto;
}

.employ.photo {
    flex: 0 0 290px;
}

.employ.texts {
    display: flex;
    flex-flow: column;
    padding-left: 10%;
    justify-content: space-evenly;
    gap: .25rem;
}

.employ.name {
    font-weight: bold;
}










