/*
Theme Name: WP Bootstrap Starter
Theme URI: https://afterimagedesigns.com/wp-bootstrap-starter/
Author: Afterimage Designs
Author URI: https://afterimagedesigns.com/
Description:  The best WordPress starter theme based on the most powerful frameworks in the world: "_s" (by Automattic, the main people behind WordPress development), Twitter Bootstrap (the most popular HTML, CSS, and JS framework for developing responsive, mobile first projects on the web) and Font Awesome (or Fontawesome, a full suite of 675+ pictographic icons for easy scalable vector graphics on websites). This theme, like WordPress, is licensed under the GPL. You can use this theme as base for your next WordPress theme project and you are allowed to remove the link at the footer or do whatever you want. Your feedback on how we can continuously improve this WordPress Starter Theme Bootstrap will be highly appreciated. Page templates includes Right-sidebar (default page template), Left-Sidebar, Full-Width, Blank with container, Blank without container Page. Other features - Currently using Bootstrap v4.0.0 , Widgetized footer area, WooCommerce ready, Compatible with Contact Form 7, Compatible with Visual Composer, Compatible with Elementor Page Builder. This theme will be an active project which we will update from time to time. Check this page regularly for the updates.
Version: 3.3.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: wp-bootstrap-starter
Requires at least: 4.7
Requires PHP: 5.2.4
Tested up to: 5.4
Tags: blog, custom-menu, featured-images, threaded-comments, translation-ready, right-sidebar, custom-background, e-commerce, theme-options, sticky-post, full-width-template
*/
/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Normalize
# Typography
# Elements
# Forms
# Navigation
	## Links
	## Menus
# Accessibility
# Alignments
# Clearings
# Widgets
# Content
	## Posts and pages
	## Comments
# Infinite scroll
# Media
	## Captions
	## Galleries
# Woocommerce
# Footer
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
body {
  margin: 0;
  -webkit-font-smoothing: auto;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block;
}

audio,
canvas,
progress,
video {
  display: inline-block;
  vertical-align: baseline;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

[hidden],
template {
  display: none;
}

a {
  background-color: transparent;
}

a:active,
a:hover {
  outline: 0;
}

dfn {
  font-style: italic;
}

mark {
  background: #ff0;
  color: #000;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

img {
  border: 0;
}

svg:not(:root) {
  overflow: hidden;
}

figure {
  margin: 1em 2.5rem;
}

hr {
  box-sizing: content-box;
  height: 0;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer;
}

button[disabled],
html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}

input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

legend {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
}

optgroup {
  font-weight: bold;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/
h1, h2, h3, h4, h5, h6 {
  clear: both;
  color: #24292e;
  font-weight: 600;
  margin-top: 24px;
  margin-bottom: 15px;
}
h1 {
  font-size: 32px;
  padding-bottom: 10px;
}
h2 {
  font-size: 24px;
  padding-bottom: 0.3em;
  line-height: 1.25;
}
h3 {
  font-size: 18px;
  line-height: 25px;
}
h4 {
  font-size: 16px;
  line-height: 20px;
}
h5 {
  font-size: 14px;
  line-height: 17.5px;
}

p {
  margin-bottom: 1.5em;
}
h1.entry-title {
  font-size: 1.31rem;
  border-bottom: 1px solid #eaecef;
}
h2.entry-title {
  border-bottom: 1px solid #eaecef;
}
h3.widget-title {
  font-size: 1.2rem;
}

/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
body {
  background: #fff;
  /* Fallback for when there is no custom background color defined. */
}

img {
  height: auto;
  /* Make sure images are scaled correctly. */
  max-width: 100%;
  /* Adhere to container width. */
}

figure {
  margin: 1em 0;
  /* Extra wide images within figure tags don't overflow the content area. */
}

table {
  margin: 0 0 1.5em;
  width: 100%;
}

/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Navigation
--------------------------------------------------------------*/
header#masthead {
  margin-bottom: 0;
  background-color: #563d7c ;
  box-shadow: 0 0.5rem 1rem rgba(0,0,0,.05), inset 0 -1px 0 rgba(0,0,0,.1);
  padding: .74rem 1rem;
}

.navbar-brand > a {
  color: rgba(0, 0, 0, 0.9);
  font-size: 1.1rem;
  outline: medium none;
  text-decoration: none;
  color: #fff;
  font-weight: 700;
}

.navbar-brand > a:visited, .navbar-brand > a:hover {
  text-decoration: none;
}

#page-sub-header {
  position: relative;
  padding-top: 5rem;
  padding-bottom: 0;
  text-align: center;
  font-size: 1.25rem;
  background-size: cover !important;
}

body:not(.theme-preset-active) #page-sub-header h1 {
  line-height: 1.6;
  font-size: 4rem;
  color: #563e7c;
  margin: 0 0 1rem;
  border: 0;
  padding: 0;
}

#page-sub-header p {
  margin-bottom: 0;
  line-height: 1.4;
  font-size: 1.25rem;
  font-weight: 300;
}
body:not(.theme-preset-active) #page-sub-header p {
color: #212529;
}
a.page-scroller {
  color: #333;
  font-size: 2.6rem;
  display: inline-block;
  margin-top: 2rem;
}

@media screen and (min-width: 768px) {
  body:not(.theme-preset-active) #page-sub-header h1 {
    font-size: 3.750rem;
  }
  body:not(.theme-preset-active) #page-sub-header {
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 992px) {
  #page-sub-header p {
    max-width: 43rem;
    margin: 0 auto;
  }
}
/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
#masthead nav {
  padding-left: 0;
  padding-right: 0;
}

body:not(.theme-preset-active) #masthead .navbar-nav > li > a {
  color: #cdbfe3;
  padding: 0.5rem;
  font-weight: 500;
  font-size: 0.875rem;
}

body:not(.theme-preset-active) #masthead .navbar-nav > li > a:hover,
body:not(.theme-preset-active) #masthead .navbar-nav > li.current_page_item > a {
  color: #fff;
  font-weight: 600;
  /*background: #f9f9f9;*/
}

.navbar-brand {
  height: auto;
}

.navbar-toggle .icon-bar {
  background: #000 none repeat scroll 0 0;
}

.dropdown-menu .dropdown-toggle::after {
  border-bottom: 0.3em solid transparent;
  border-left: 0.3em solid;
  border-top: 0.3em solid transparent;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children {
    position: relative;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children>.dropdown-menu {
    top: 0;
    left: 100%;
    margin-top: -6px;
    margin-left: -1px;
    -webkit-border-radius: 0 6px 6px 6px;
    -moz-border-radius: 0 6px 6px;
    border-radius: 0 6px 6px 6px;
}
.dropdown.menu-item-has-children .dropdown.menu-item-has-children:hover>.dropdown-menu {
    display: block;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children>a:after {
    display: block;
    content: " ";
    float: right;
    width: 0;
    height: 0;
    border-color: transparent;
    border-style: solid;
    border-width: 5px 0 5px 5px;
    border-left-color: #ccc;
    margin-top: 5px;
    margin-right: -10px;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children:hover>a:after {
    border-left-color: #fff;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children.pull-left {
    float: none;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children.pull-left>.dropdown-menu {
    left: -100%;
    margin-left: 10px;
    -webkit-border-radius: 6px 0 6px 6px;
    -moz-border-radius: 6px 0 6px 6px;
    border-radius: 6px 0 6px 6px;
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
  display: block;
}

.dropdown-item {
  line-height: 1.2;
  padding-bottom: 0.313rem;
  padding-top: 0.313rem;
}

.dropdown-menu {
  min-width: 12.500rem;
}

.dropdown .open .dropdown-menu {
  display: block;
  left: 12.250em;
  top: 0;
}

.dropdown-menu .dropdown-item {
  white-space: normal;
  background: transparent;
  line-height: 1.6;
}
.dropdown-menu .dropdown-item:hover {
  background: transparent;
}

@media screen and (min-width: 37.5em) {
  .menu-toggle {
    display: none;
  }
}
@media screen and (min-width: 769px) {
  .dropdown-menu li > .dropdown-menu {
    right: -9.875rem;
    top: 1.375rem;
  }
}
@media screen and (max-width: 991px) {
  .navbar-nav .dropdown-menu {
    border: medium none;
    margin-left: 1.250rem;
    padding: 0;
  }

  .dropdown-menu li a {
    padding: 0;
  }

  #masthead .navbar-nav > li > a {
    padding-bottom: 0.625rem;
    padding-top: 0.313rem;
  }

  .navbar-light .navbar-toggler {
    border: medium none;
    outline: none;
  }
}

.site {
	margin:36px auto;
}

.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
  margin: 0 0 1.5em;
  overflow: hidden;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
  float: left;
  width: 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
  float: right;
  text-align: right;
  width: 50%;
}
.comment-content.card-block {
  padding: 20px;
}

.navigation.post-navigation {
  padding-top: 1.875rem;
}

.post-navigation .nav-previous a,
.post-navigation .nav-next a {
  border: 1px solid #ddd;
  border-radius: 0.938rem;
  display: inline-block;
  padding: 0.313rem 0.875rem;
  text-decoration: none;
}

.post-navigation .nav-next a::after {
  content: " \2192";
}

.post-navigation .nav-previous a::before {
  content: "\2190 ";
}

.post-navigation .nav-previous a:hover,
.post-navigation .nav-next a:hover {
  background: #eee none repeat scroll 0 0;
}

/*--------------------------------------------------------------
# Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers. */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  word-wrap: normal !important;
  /* Many screen reader and browser combinations announce broken words as they would appear visually. */
}
.screen-reader-text:focus {
  background-color: #f1f1f1;
  border-radius: 3px;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  color: #21759b;
  display: block;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: bold;
  height: auto;
  left: 0.313rem;
  line-height: normal;
  padding: 0.938rem 1.438rem 0.875rem;
  text-decoration: none;
  top: 0.313rem;
  width: auto;
  z-index: 100000;
  /* Above WP toolbar. */
}

/* Do not show the outline on the skip link target. */
#content[tabindex="-1"]:focus {
  outline: 0;
}

/*--------------------------------------------------------------
# Alignments
--------------------------------------------------------------*/
.alignleft {
  display: inline;
  float: left;
  margin-right: 1.5em;
}

.alignright {
  display: inline;
  float: right;
  margin-left: 1.5em;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

a img.alignright {
  float: right;
  margin: 0.313rem 0 1.25rem 1.25rem;
}

a img.alignnone {
  margin: 0.313rem 1.25rem 1.25rem 0;
}

a img.alignleft {
  float: left;
  margin: 0.313rem 1.25rem 1.25rem 0;
}

a img.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.wp-caption.alignnone {
  margin: 0.313rem 1.25rem 1.25rem 0;
}

.wp-caption.alignleft {
  margin: 0.313rem 1.25rem 1.25rem 0;
}

.wp-caption.alignright {
  margin: 0.313rem 0 1.25rem 1.25rem;
}

/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
  content: "";
  display: table;
  table-layout: fixed;
}

.clear:after,
.entry-content:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after {
  clear: both;
}

/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widget {
  margin: 0 0 1.5em;
  font-size: 0.875rem;
  /* Make sure select elements fit in widgets. */
}
.widget select {
  max-width: 100%;
}

.widget_search .search-form input[type="submit"] {
  display: none;
}

.nav > li > a:focus,
.nav > li > a:hover {
  background-color: #eee;
  text-decoration: none;
}
.half-rule {
  width: 6rem;
  margin: 2.5rem 0;
}
.widget_categories .nav-link {
  display: inline-block;
}

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Posts and pages
--------------------------------------------------------------*/
#content.site-content {
  padding-bottom: 0.75rem;
  padding-top: 1.125rem;
}

.sticky .entry-title::before {
  content: '\f08d';
  font-family: "Font Awesome\ 5 Free";
  font-size: 1.563rem;
  left: -2.5rem;
  position: absolute;
  top: 0.375rem;
  font-weight: 900;
}

.sticky .entry-title {
  position: relative;
}

.single .byline,
.group-blog .byline {
  display: inline;
}

.page-content,
.entry-content,
.entry-summary {
  margin: 1.5em 0 0;
}

.page-links {
  clear: both;
  margin: 0 0 1.5em;
}

.page-template-blank-page .entry-content,
.blank-page-with-container .entry-content {
  margin-top: 0;
}

.post.hentry {
  margin-bottom: 4rem;
}

.posted-on, .byline, .comments-link {
  color: #9a9a9a;
}

.entry-title > a {
  color: inherit;
}

/*--------------------------------------------------------------
## Comments
--------------------------------------------------------------*/
.comment-content a {
  word-wrap: break-word;
}

.bypostauthor {
  display: block;
}

.comment-body .pull-left {
  padding-right: 0.625rem;
}

.comment-list .comment {
  display: block;
}

.comment-list {
  padding-left: 0;
}

.comments-title {
  font-size: 1.125rem;
}

.comment-list .pingback {
  border-top: 1px solid rgba(0, 0, 0, 0.125);
  padding: 0.563rem 0;
}

.comment-list .pingback:first-child {
  border: medium none;
}

/*--------------------------------------------------------------
# Infinite scroll
--------------------------------------------------------------*/
/* Globally hidden elements when Infinite Scroll is supported and in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
  /* Theme Footer (when set to scrolling) */
  display: none;
}

/* When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. */
.infinity-end.neverending .site-footer {
  display: block;
}

/*--------------------------------------------------------------
# Media
--------------------------------------------------------------*/
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
  border: none;
  margin-bottom: 0;
  margin-top: 0;
  padding: 0;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
  max-width: 100%;
}

/*--------------------------------------------------------------
## Captions
--------------------------------------------------------------*/
.wp-caption {
  background: #f1f1f1 none repeat scroll 0 0;
  border: 1px solid #f0f0f0;
  max-width: 96%;
  padding: 0.313rem 0.313rem 0;
  text-align: center;
}
.wp-caption img[class*="wp-image-"] {
  border: 0 none;
  height: auto;
  margin: 0;
  max-width: 100%;
  padding: 0;
  width: auto;
}
.wp-caption .wp-caption-text {
  font-size: 0.688rem;
  line-height: 1.063rem;
  margin: 0;
  padding: 0.625rem;
}

.wp-caption-text {
  text-align: center;
}

/*--------------------------------------------------------------
## Galleries
--------------------------------------------------------------*/
.gallery {
  margin-bottom: 1.5em;
}

.gallery-item {
  display: inline-block;
  text-align: center;
  vertical-align: top;
  width: 100%;
}
.gallery-item .gallery-columns-2 {
  max-width: 50%;
}
.gallery-item .gallery-columns-3 {
  max-width: 33.33333%;
}
.gallery-item .gallery-columns-4 {
  max-width: 25%;
}
.gallery-item .gallery-columns-5 {
  max-width: 20%;
}
.gallery-item .gallery-columns-6 {
  max-width: 16.66667%;
}
.gallery-item .gallery-columns-7 {
  max-width: 14.28571%;
}
.gallery-item .gallery-columns-8 {
  max-width: 12.5%;
}
.gallery-item .gallery-columns-9 {
  max-width: 11.11111%;
}

.gallery-caption {
  display: block;
}

/*--------------------------------------------------------------
# Plugin Compatibility
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Woocommerce
--------------------------------------------------------------*/
.woocommerce-cart-form .shop_table .coupon .input-text {
  width: 8.313rem !important;
}

.variations_form .variations .value > select {
  margin-bottom: 0.625rem;
}

.woocommerce-MyAccount-content .col-1,
.woocommerce-MyAccount-content .col-2 {
  max-width: 100%;
}

/*--------------------------------------------------------------
## Elementor
--------------------------------------------------------------*/
.elementor-page article .entry-footer {
  display: none;
}

.elementor-page.page-template-fullwidth #content.site-content {
  padding-bottom: 0;
  padding-top: 0;
}

.elementor-page .entry-content {
  margin-top: 0;
}

/*--------------------------------------------------------------
## Visual Composer
--------------------------------------------------------------*/
.vc_desktop article .entry-footer {
  display: none;
}

.vc_desktop #content.site-content {
  padding-bottom: 0;
  padding-top: 0;
}

.vc_desktop .entry-content {
  margin-top: 0;
}

/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
footer#colophon {
  font-size: 85%;
}
body:not(.theme-preset-active) footer#colophon {
  color: #99979c;
  background-color: #f7f7f7;
}
.navbar-dark .site-info {
  color: #fff;
}
.copyright {
  font-size: 0.875rem;
  margin-bottom: 0;
  text-align: center;
}

.copyright a, footer#colophon a {
  color: inherit;
}

.language-selector {
  background: #f7fafc;
  border-radius: 10px;
  padding: 8px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: background 0.3s ease;
}

.language-selector:hover {
  background: #edf2f7;
}

.language-select {
  background: transparent;
  border: none;
  font-weight: 500;
  color: #4a5568;
  cursor: pointer;
  font-size: 14px;
}







    /* Reset */
    *,*::before,*::after{box-sizing:border-box}
    html,body{height:100%}
    body{margin:0;font-family:Inter, Roboto, system-ui,-apple-system,"Segoe UI",Arial;line-height:1.45;color:#0b2135;background:#f7f9fb}

    /* Theme colors */
    :root{
      --blue:#0b56a6; /* deep blue */
      --blue-2:#0f73d1;
      --orange:#ff7a18; /* vivid orange */
      --muted:#8aa0b8;
      --card:#ffffff;
          --primary-blue: #003366; /* Глубокий синий */
    --primary-dark: #001f3f;
    --accent-orange: #FF6600; /* Промышленный оранжевый */
    --accent-hover: #e65c00;
    --light-bg: #f4f7f6;
    --white: #ffffff;
    --text-main: #333333;
    --text-light: #666666;
      --glass: rgba(255,255,255,0.7);
      --accent-gradient: linear-gradient(90deg,var(--orange),var(--blue-2));
      --radius:14px;
    }

    /* Layout */
    .wrap{max-width:1400px;margin:36px auto;}
    header.site{background:var(--card);border-radius:18px;padding:18px 22px;box-shadow:0 8px 30px rgba(15,23,42,0.06);display:flex;align-items:center;gap:20px}
    .logo{display:flex;align-items:center;gap:15px;width: 30%;}
    .logo img {
          width: 110px;
    }
    .logo .mark{width:56px;height:56px;border-radius:10px;display:grid;place-items:center;background:var(--accent-gradient);color:#fff;font-weight:700;font-size:18px}
    .logo h1{
          margin: 0;
    font-size: 18px;
    color: var(--primary-blue);
    line-height: normal;
    }
    nav.top{
    margin-left: auto;
    display: flex;
    align-items: center;
}

.site-nm {
	    width: 75%;
}

.site-nm a {
	margin: 0;
    font-size: 18px;
    color: #003366;
    line-height: normal;
    margin-bottom: 5px;
	padding-bottom: 0;
	font-weight: 700;
}
    nav.top ul{display:flex;gap:12px;list-style:none;padding:0;margin:0}
    nav.top a{display:inline-block;padding:8px 12px;border-radius:10px;color:var(--primary-blue);text-decoration:none;font-weight:600}
   .cta {
    background: var(--orange);
    color: #fff !important;
    padding: 8px 14px !important;
    border-radius: 10px !important;
}

    /* Hero */
    .hero{display:grid;grid-template-columns:1fr 460px;gap:28px;align-items:center;margin-top:26px}
    .hero-card{background:linear-gradient(180deg,rgba(255,255,255,0.9),rgba(255,255,255,0.85));padding:26px;border-radius:18px;box-shadow:0 20px 50px rgba(11,33,53,0.06)}
    .hero h2{
	color: #003366;
    margin: 0 0 12px;
    font-size: 28px;
    font-weight: bold;
}
    .hero p{margin:0 0 18px;color:var(--muted)}
    .badges{display:flex;gap:8px;flex-wrap:wrap}
    .badge{background:linear-gradient(90deg,#fff, rgba(255,255,255,0.8));border:1px solid rgba(11,33,53,0.04);padding:8px 10px;border-radius:12px;font-weight:600}

    .hero-visual{background:var(--primary-blue);border-radius:18px;padding:18px;color:#fff;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center}
    .hero-visual img{max-width:100%;border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,0.12)}



    /* Sidebar */
    aside.side{background:var(--card);padding:18px;border-radius:16px;box-shadow:0 8px 30px rgba(11,33,53,0.04);height:max-content}
    .stat{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
    .stat strong{font-size:20px;color:var(--primary-blue)}
    .contact{margin-top:10px}
    .contact a{display:block;color:var(--primary-blue);text-decoration:none;margin-bottom:6px}

    /* Achievements */
 .achievements {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

.ach {
    background: #ffffff;
    padding: 22px 18px;
    border-radius: 16px;
    text-align: center;
    box-shadow: 0 8px 25px rgba(0,0,0,0.06);
    border: 1px solid #eef1f6;
    transition: .3s ease;
    position: relative;
    overflow: hidden;
}

/* эффект подсветки при наведении */
.ach:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 35px rgba(0,0,0,0.10);
}

/* Красивая подложка-градлеант */
.ach::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,122,0,0.12), rgba(0,91,255,0.12));
    opacity: 0;
    transition: .3s;
}
.ach:hover::before { opacity: 1; }

/* Иконки */
.ach-icon {
    width: 55px;
    height: 55px;
    margin: 0 auto 12px;
    border-radius: 14px;
    background: linear-gradient(135deg, #ff7a00, #ff9f3f);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-size: 26px;
    box-shadow: 0 6px 15px rgba(255,122,0,0.35);
    transition: .3s;
}

.ach:hover .ach-icon {
    transform: scale(1.08);
}

/* Число */
.ach .num {
    font-size: 26px;
    font-weight: 800;
    color: var(--primary-blue);
    margin-bottom: 6px;
}

/* Подпись */
.ach p {
    margin: 0;
    color: var(--muted);
    font-size: 14px;
    font-weight: 500;
}

/* Адаптив */
@media (max-width: 768px) {
    .achievements {
        grid-template-columns: repeat(2, 1fr);
        gap: 14px;
    }
}


    /* Projects */
    .projects{background:var(--card);padding:18px;border-radius:16px}
    .gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
    .card{border-radius:12px;overflow:hidden;border:1px solid rgba(11,33,53,0.04);background:#fff}
    .card img{width:100%;height:160px;object-fit:cover}
    .card .title{padding:10px;font-weight:700;color:var(--primary-blue)}

/* Reviews */
 
.reviews-section {

}

.reviews-slider-wrapper {
    overflow: hidden;
    position: relative;
}

.reviews-slider {
    display: flex;
    gap: 20px;
    transition: transform 0.5s ease;
}

.review-slide {
    flex: 0 0 48%;
    background: linear-gradient(180deg,#fff,#fbfdff);
    padding: 25px 20px;
    border-radius: 16px;
    box-shadow: 0 8px 25px rgba(0,0,0,0.08);
}

.review-text {
    font-size: 16px;
    color: #555;
    margin-bottom: 15px;
    line-height: 1.6;
    font-style: italic;
}

.review-author {
    display: block;
    font-weight: 700;
    color: var(--primary-blue);
    font-size: 16px;
}

/* Навигация */
.slider-nav {
    margin-top: 25px;
}

.slider-nav button {
    background: var(--orange);
    border: none;
    padding: 10px 16px;
    border-radius: 8px;
    margin: 0 5px;
    color: #fff;
    font-size: 16px;
    cursor: pointer;
    transition: 0.3s;
}

.slider-nav button:hover {
    background: #ff9f3f;
}

/* Адаптив */
@media (max-width: 768px) {
    .review-slide { flex: 0 0 100%; }
}




    /* Footer */
  footer {
    margin-top: 28px;
    padding: 25px 40px;
    border-radius: 12px;
    background: linear-gradient(90deg, rgba(11,86,166,0.05), rgba(255,122,24,0.02));
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
}

.footer-left {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.footer-logo {
    max-width: 140px;
    margin-bottom: 6px;
}

.footer-company {
    font-weight: 800;
    color: var(--primary-blue);
    font-size: 16px;
}

.footer-copy {
    font-size: 14px;
    color: #555;
}

.footer-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
}

.footer-dev {
    font-size: 14px;
    color: #555;
}

.footer-socials a {
    margin-left: 10px;
    color: var(--primary-blue);
    font-size: 18px;
    transition: 0.3s;
}

.footer-socials a:hover {
    color: var(--accent-orange);
}

/* Адаптив */
@media (max-width: 768px) {
    footer {
flex-direction: column;
        align-items: center;
        text-align: left;
        display: flex;
    }
    .footer-right {
        align-items: center;
    }
    .footer-socials a {
        margin-left: 0;
        margin-right: 12px;
    }
}

    /* Modal */
    .modal{position:fixed;inset:0;display:none;place-items:center;background:rgba(2,6,23,0.5);z-index:40}
    .modal.open{display:grid}
    .modal .panel{background:var(--card);padding:18px;border-radius:12px;max-width:920px;width:100%;display:grid;grid-template-columns:1fr 320px;gap:18px}

    /* Responsive */
    @media (max-width:980px){
      .hero{grid-template-columns:1fr}
      .catalog{grid-template-columns:1fr}
      .grid{grid-template-columns:1fr}
      .projects .gallery{grid-template-columns:repeat(2,1fr)}
      nav.top ul{display:none}
    }
    @media (max-width:520px){
      .projects .gallery{grid-template-columns:1fr}
      header.site{flex-direction:column;align-items:flex-start}
    }

    /* Small touches */
    .muted{color:var(--muted)}
    .pill{padding:6px 10px;border-radius:999px;background:rgba(11,86,166,0.08);color:var(--primary-blue);font-weight:700}
    .tag{font-size:12px;padding:6px 8px;border-radius:8px;border:1px solid rgba(11,33,53,0.04)}


/* Каталог */
.catalog-filters { display: flex; justify-content: center; gap: 15px; margin-bottom: 40px; flex-wrap: wrap; }
.filter-btn {
    background: var(--white); border: 1px solid #ddd; padding: 5px 20px; border-radius: 20px;
    cursor: pointer; font-weight: 500; transition: var(--transition);
	    font-size: 14px;
}
.filter-btn:hover, .filter-btn.active { background: var(--primary-blue); color: var(--white); border-color: var(--primary-blue); }


/* Карточка товара */
.product-card {
    background: var(--white); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow);
    transition: var(--transition); cursor: pointer; border: 1px solid transparent; display: flex; flex-direction: column;
}
.product-card:hover { transform: translateY(-5px); border-color: #ff6600; }
.card-img { height: 200px; background: #eee; display: flex; align-items: center; justify-content: center; color: #999; }
.card-body { padding: 20px; flex-grow: 1; display: flex; flex-direction: column; }
.card-cat { font-size: 12px; color: #ff6600; text-transform: uppercase; font-weight: 700; margin-bottom: 5px; }
.card-title { font-size: 18px; color: var(--primary-blue); margin-bottom: 10px; font-weight: 600; }
.card-link { margin-top: auto; color: var(--primary-blue); font-weight: 600; font-size: 14px; }
.card-link:hover { color: #ff6600; }
.catalog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 30px; }
.section-title {
    font-size: 24px;
    color: var(--primary-blue);
    margin-bottom: 35px;
    font-weight: 700;
    margin-top: 50px;
    position: relative;
    display: inline-block; /* чтобы линия была под текстом */
}

.section-title::after {
content: "";
    position: absolute;
    right: 0;
    bottom: -5px;
    width: 60px;
    height: 4px;
    background: #ff7a00;
    border-radius: 2px;
}


.card-img img {
      height: 100%;
    width: 100%;
    object-fit: contain;
}

/* Модальное окно */
.modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.8);
    z-index: 1000; display: none; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.3s;
}
.modal-overlay.open { display: flex; opacity: 1; }
.modal-content {
    background: var(--white); width: 90%; max-width: 900px; border-radius: var(--radius);
    position: relative; overflow: hidden; animation: slideUp 0.3s ease;
}
.close-modal { position: absolute; top: 15px; right: 20px; font-size: 30px; background: none; border: none; cursor: pointer; color: #333; z-index: 10; }
.modal-body { display: grid; grid-template-columns: 1fr 1fr; padding:0;}
.modal-img-container { background: #f0f0f0; height: 100%; min-height: 400px; display: flex; align-items: center; justify-content: center; }
.modal-details { padding: 40px; }
.badge { background: var(--primary-blue); color: var(--white); padding: 6px 10px; border-radius: 4px; font-size: 12px; text-transform: uppercase; }
#modal-title { margin: 15px 0; font-size: 28px; color: var(--primary-blue); }
.specs-list { margin: 20px 0; border-top: 1px solid #eee; padding-top: 10px; padding-inline-start: 0px;}
.specs-list li { display: flex; justify-content: space-between; margin-bottom: 8px; font-size: 14px; }
.specs-list span { color: #888; }
.full-width { width: 100%; text-align: center; }

@keyframes slideUp { from { transform: translateY(50px); } to { transform: translateY(0); } }

/* Адаптив */
@media (max-width: 768px) {
    .nav-links, .btn-outline { display: none; }
    .burger-menu { display: block; }
    .hero h1 { font-size: 32px; }
    .hero-stats { flex-wrap: wrap; gap: 20px; }
    .split-layout, .contact-card, .modal-body { grid-template-columns: 1fr; }
    .modal-img-container { height: 250px; min-height: auto; }
}

.full-width {
    width: 100%;
    text-align: center;
}

.btn-primary {
    background: var(--accent-orange);
    color: var(--white);
}

.btn {
    display: inline-block;
    padding: 12px 28px;
    border-radius: var(--radius);
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: var(--transition);
}

/* Контакты */
.contact-card {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: var(--white);
    box-shadow: 0 8px 25px rgba(0,0,0,0.08);
    border-radius: 16px;
    overflow: hidden;
    gap: 0;
}

.contact-info {
    background: var(--primary-blue);
    color: var(--white);
    padding: 50px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

/* Новый грид для двух колонок */
.info-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px 40px;
}

/* Стили для каждого блока */
.info-item {
    display: flex;
    gap: 15px;
    align-items: flex-start;
}

.contact-info h2 {
    margin-bottom: 30px;
    font-size: 28px;
    font-weight: 700;
	color: white;
}

.info-item {
    display: flex;
    gap: 20px;
    margin-bottom: 25px;
    align-items: flex-start;
}

.info-item i {
    font-size: 28px;
    color: var(--accent-orange);
    flex-shrink: 0;
    margin-top: 4px;
}

.info-item h4 {
    margin: 0 0 5px 0;
    font-weight: 600;
	color: white;
}

.info-item p {
    margin: 0;
    font-size: 15px;
    line-height: 1.5;
}

.contact-form {
    padding: 50px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.contact-form h3 {
    margin-bottom: 25px;
    font-size: 24px;
    color: var(--primary-blue);
}

.contact-form input,
.contact-form textarea {
    width: 100%;
    padding: 14px;
    margin-bottom: 15px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-family: inherit;
    font-size: 14px;
    transition: 0.3s;
}

.contact-form input:focus,
.contact-form textarea:focus {
    border-color: var(--accent-orange);
    outline: none;
}

.contact-form textarea {
    height: 140px;
    resize: vertical;
}

.contact-form .btn-primary {
    background: var(--accent-orange);
    color: #fff;
    border: none;
    padding: 12px 20px;
    border-radius: 8px;
    font-size: 16px;
    cursor: pointer;
    transition: 0.3s;
}

.contact-form .btn-primary:hover {
    background: #ff9f3f;
}

.footer-company a {
	    font-weight: 800;
    color: #003366;
    font-size: 16px;
}

.footer-dev a {
	color: #8aa0b8;
}

/* Адаптив */
@media (max-width: 992px) {
    .contact-card {
        grid-template-columns: 1fr;
    }
    .contact-info, .contact-form {
        padding: 30px;
    }
}



/* О компании */
.split-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
.check-list li { margin-bottom: 15px; display: flex; align-items: center; gap: 10px; font-weight: 500; }
.check-list i { color: var(--accent-orange); }
.image-block {
    width: 100%;
    margin-top: 20px;
}

.placeholder-img {
    width: 100%;
    height: 390px;
    border-radius: 16px;
    overflow: hidden; /* главное — скрывает края картинки */
    position: relative;
    background: #f3f4f6;
    box-shadow: 0 8px 22px rgba(0,0,0,0.08);
}

.placeholder-img img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* чтобы картинка красиво обрезалась */
    border-radius: inherit;
    transition: transform .4s ease;
}

.placeholder-img:hover img {
    transform: scale(1.05); /* лёгкое увеличение */
}

.proj-txt {
  padding: 10px;
}

/* ============================
   Мобильная версия (до 768px)
   ============================ */
@media (max-width: 768px) {

    .container header.site {
        display: flex;
        flex-direction: column;
        align-items: center;
        padding: 15px 10px;
        gap: 15px;
    }

    /* Логотип + название */
    .logo {
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 10px;
    }

    .logo img {
        max-width: 140px;
        height: auto;
    }

    .site-nm h1 {
        font-size: 20px;
        margin: 0;
        line-height: 1.2;
    }

    .site-nm .muted {
        font-size: 12px !important;
        opacity: 0.8;
        max-width: 260px;
        margin: 0 auto;
    }

    /* Меню */
    nav.top {
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 12px;
        text-align: center;
    }

    nav.top ul {
        display: flex;
        flex-direction: column;
        width: 100%;
        gap: 8px;
        padding: 0;
        margin: 0;
    }

    nav.top ul li {
        list-style: none;
    }

    nav.top ul li a {
        padding: 10px 0;
        display: block;
        font-size: 16px;
    }

    /* Кнопка "Связаться" */
    nav.top .cta {
        background: #f57c00;
        color: #fff;
        padding: 12px 24px;
        border-radius: 6px;
        text-decoration: none;
        font-weight: 600;
        font-size: 15px;
        width: 100%;
        max-width: 260px;
        text-align: center;
        transition: 0.3s;
    }

    nav.top .cta:hover {
        background: #e36f00;
    }

    /* Переключатель языка */
    .language-selector {
        display: flex;
        align-items: center;
        gap: 8px;
        margin-top: 5px;
        justify-content: center;
        width: 100%;
    }

    .language-selector svg {
        width: 18px;
        height: 18px;
    }

    .language-select {
        padding: 6px 10px;
        font-size: 14px;
        border-radius: 5px;
        border: 1px solid #ccc;
    }
	
	.split-layout {
    display: flex;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    align-items: center;
    flex-direction: column;
}
	
.info-grid {
    display: flex;
    gap: 10px 40px;
    flex-direction: column;
    margin-bottom: 15px;
}	
	
.footer-company {
    font-weight: 800;
    color: var(--primary-blue);
    font-size: 16px;
    text-align: center;
}
	
.footer-left {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: center;
}	

}






.catalog-wrapper {
    margin: 0 auto;
}

.catalog-section-title {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 25px;
    color: #003366;
    border-left: 6px solid #ff6600;
    padding-left: 15px;
    line-height: 1.2;
}

.catalog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
    gap: 25px;
}

.catalog-item {
    background: #fff;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid #e0e0e0;
    padding: 15px;
    transition: .25s ease;
    position: relative;
}

.catalog-item:hover {
    transform: translateY(-4px);
    border-color: #ff6600;
    box-shadow: 0 6px 22px rgba(0,0,0,0.12);
}

.catalog-thumb-wrapper {
    width: 100%;
    height: 180px;
    margin-bottom: 15px;
    border-radius: 10px;
    overflow: hidden;
    background: #f4f4f4;
    display: flex;
    align-items: center;
    justify-content: center;
}

.catalog-thumb {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.catalog-item-title {
    font-size: 18px;
    font-weight: 600;
    color: #222;
    margin-bottom: 10px;
    line-height: 1.3;
	    text-decoration: none; 
    color: #000;
    transition: color 0.3s ease;
    cursor: pointer; 
}
.catalog-item-title:hover {
    color: orange; 
    text-decoration: none; 
}

.catalog-item-title a {
    text-decoration: none;
    color: #000;
    transition: color 0.3s ease;
}

.catalog-item-title a:hover {
    color: orange;
    text-decoration: none;
}

.catalog-item a {
    text-decoration: none;
    color: inherit; 
}

.catalog-item-title {
    transition: color 0.3s ease; 
    color: #000;
}

.catalog-item:hover .catalog-item-title {
    color: orange; 
}


.catalog-item-desc {
    font-size: 14px;
    color: #444;
    line-height: 1.45;
}

.catalog-item-desc p {
    margin: 0 0 6px 0;
}

.no-products {
    color: #888;
    font-style: italic;
    padding: 10px 0;
}









@media (max-width: 576px) {
    .catalog-grid {
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    }

    .catalog-thumb-wrapper {
        height: 130px;
    }

    .catalog-item-title {
        font-size: 16px;
    }
}





.related-products-section {
    margin-top: 50px;
    padding-top: 30px;
    border-top: 1px solid #eee;
}

.related-products-section h3 {
    margin-bottom: 20px;
    font-size: 24px;
    color: #333;
    text-align: left;
}

.related-products-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.related-product-card {
    width: calc(16.66% - 17.33px); /* 6 карточек в ряд */
    background: #fff;
    border: 1px solid #eee;
    border-radius: 8px;
    overflow: hidden;
    transition: transform 0.3s, box-shadow 0.3s;
}

.related-product-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0,0,0,0.1);
}

.related-product-thumb img {
    width: 100%;
    display: block;
}

.related-product-title {
    padding: 10px;
    font-size: 13px;
    font-weight: 600;
    color: #000;
    text-align: center;
    transition: color 0.3s;
}

.related-product-card:hover .related-product-title {
    color: orange;
}

.related-product-link {
    text-decoration: none;
    color: inherit;
}



.post-wrapper {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    margin-bottom: 40px;
    flex-wrap: wrap; 
}

.post-content {
    flex: 1 1 60%;
    min-width: 250px;
}

.post-thumbnail {
    flex: 0 0 35%;
    min-width: 200px;
}

.post-thumbnail img {
    width: 100%;
    height: auto;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}

.entry-title {
    font-family: 'Arial', sans-serif;
    font-weight: 700;
    color: #ff6600; 
    margin-bottom: 10px;
}

.entry-title a {
    text-decoration: none;
    color: inherit;
}

.entry-meta {
    font-size: 14px;
    color: #777;
    margin-bottom: 15px;
}

.post-excerpt {
    font-size: 16px;
    line-height: 1.6;
    color: #333;
}

.mini-opisanie {
    margin-top: 10px;
    font-size: 14px;
    color: #555;
    line-height: 1.5;
    text-align: left;
    white-space: pre-line;
}

.show-more-container {
	display: flex;
    justify-content: center;
}

#show-more:hover {
	background: #e1600b;
    color: var(--white);
}

.btn-primary {
    color: #fff;
    background-color: #ff6600!important;
    border-color: #ff6600!important;
}













@media screen and (max-width: 767px) {
  #masthead .navbar-nav > li > a {
    padding-bottom: 0.938rem;
    padding-top: 0.938rem;
  }
}
/*--------------------------------------------------------------
# Media Query
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Notebook
--------------------------------------------------------------*/
@media only screen and (max-width: 1280px) {
  html {
    font-size: 95%;
  }
}

@media screen and (max-width: 1199px) {
  .navbar-dark .dropdown-item {
    color: #fff;
  }
  .navbar-nav .dropdown-menu {
    background: transparent;
    box-shadow: none;
    border: none;
  }
}
/*--------------------------------------------------------------
## Netbook
--------------------------------------------------------------*/
@media only screen and (max-width: 1024px) {
  html {
    font-size: 90%;
  }
}
/*--------------------------------------------------------------
## iPad
--------------------------------------------------------------*/
@media only screen and (max-width: 960px) {
  html {
    font-size: 85%;
  }
}
/*--------------------------------------------------------------
## iPad
--------------------------------------------------------------*/
@media only screen and (max-width: 768px) {
  html {
    font-size: 80%;
  }
	
.related-product-card {
    width: calc(51.66% - 16.33px);
    background: #fff;
    border: 1px solid #eee;
    border-radius: 8px;
    overflow: hidden;
    transition: transform 0.3s, box-shadow 0.3s;
}	
	
.post-wrapper {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    margin-bottom: 40px;
    flex-wrap: wrap;
    justify-content: center;
}	
	
.post-thumbnail {
    flex: 0 0 35%;
    min-width: 100%;
}	
	
.product-card {
    width: calc(51% - 12px);
    background: #fff;
    border: 1px solid #eee;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.3s, box-shadow 0.3s;
    display: none;
}	
	
}
/*--------------------------------------------------------------
## iPad
--------------------------------------------------------------*/
@media only screen and (max-width: 480px) {
  html {
    font-size: 75%;
  }
}

