/* =====================
   VARIABLES
   (sdílené s ostatními soubory)
   ===================== */
:root {
    --color-primary: #d11;
    --color-primary-dark: #800;
    --color-green: #006F45;
    --color-grey: #808080;
    --color-grey-dark: #666;
    --color-white: #fff;
    --color-black: #000;
    --color-text: #333;
    --color-grey-border: #ccc;
    --color-grey-hover: #eee;
    --transition-fast: all 0.3s ease;
}

/* =====================
   FOOTER
   ===================== */
#footer { padding-bottom: 30px; }

/* =====================
   LOGIN
   ===================== */
.form-login    { margin-top: 1em; }
.display-block { display: block; padding: 1em 0 0; }

/* =====================
   SDÍLENÉ OPAKUJÍCÍ SE BLOKY
   (použito ve více breakpointech)
   ===================== */

/* Slide text – mobilní varianty (768px a méně) */
.slide-text-mobile > h1 {
  padding: 0 5px;
  text-shadow: none !important;
  color: var(--color-white);
  font-size: 25px;
  line-height: 34px;
  margin-bottom: 20px;
  letter-spacing: 0;
  animation-delay: 0.7s;
}

/* =====================
   MEDIA QUERIES
   ===================== */

/* ── DESKTOP ≥ 1200px ───────────────────────── */
@media (min-width: 1200px) {
  html   { position: relative; min-height: 100%; }
  body   { margin-bottom: 300px; }
  .footer { position: absolute; bottom: 0; width: 100%; }
  .container-fluid { width: 1170px; }

  header  { padding-top: 103px; }
  .header { padding: 21px 0; }

  .powered     { margin-top: 5px; font-size: 12px; font-weight: 400; text-transform: uppercase; color: var(--color-grey-dark); }
  .powered img { height: 10px; vertical-align: -1px; }

  .motto         { margin-top: 10px; font-size: 1.25em; text-align: center; }
  .navbar-brand img { height: 40px; position: relative; top: -10px; }
  .toplinks      { padding: 5px 0; }
  .navbar        { margin-bottom: 0; }
  .bx-wrapper    { border: 0; margin: 0; }
  .htext1        { display: none; }
  .orderlink     { text-align: right; }

  .default .title-news { margin-bottom: 30px; }

  /* Formulář */
  .form-inline.cc .form-group { display: inline-block !important; vertical-align: middle; margin-bottom: 0; }

  /* Shop */
  .shop h1                   { font-size: 2.5em; }
  .shopIntro .shopItem h3    { font-size: 1.3em; padding: 10px; }
  .customdetailnote p:nth-of-type(2) { width: 50% !important; }

  /* Cart */
  .formRow .fieldset {
    background: var(--color-white);
    margin: 0 15px 15px;
    width: 46.5%;
    padding: 15px;
  }
  .formRow .fieldset .btn-default { position: absolute; right: 15px; }

  /* Navbar */
  .dropdown-menu > li > a:hover,
  .dropdown-menu > li > a:focus       { background: var(--color-primary-dark) !important; color: var(--color-white) !important; }
  .navbar-default li li li a          { padding-left: 40px !important; }

  /* Slider */
  .slider {
    display: none;
    background: url(/Content/theme/slider-bkg.jpg) top center repeat-x;
    border-bottom: 1px solid var(--color-grey-border);
    max-height: 520px;
    overflow: hidden;
    height: 480px;
  }

  /* Download table */
  .dlThumb { width: 120px; }
  .dlSize  { width: 100px; }
  .dlDate  { width: 100px; }

  .title { margin: 1em -15px 0; }
}

/* ── TABLET LANDSCAPE 992–1199px ────────────── */
@media (min-width: 992px) and (max-width: 1199px) {
  .container { width: 100%; }

  header  { padding-top: 103px; }
  .header { padding: 20px 0; }

  .logo-image img { width: 200px; height: 50px !important; }
  .powered        { margin-top: 5px; font-size: 9.75px; font-weight: 400; text-transform: uppercase; color: var(--color-grey-dark); }
  .powered img    { height: 7px; }
  .motto          { margin-top: 20px; }
  .navbar-brand img { height: 40px; position: relative; top: -10px; }
  .toplinks       { padding: 5px 0; }
  .navbar         { margin-bottom: 0; }
  .bx-wrapper     { border: 0; margin: 0; }
  .htext1         { display: none; }
  .orderlink      { text-align: right; }
  .slides         { width: 100%; margin-bottom: 1em; }

  .default .title-news  { margin-bottom: 30px; }

  /* Sekce */
  .section.exp,
  .section.faq   { padding: 15px 0; }
  .section.exp   { background: var(--color-grey-border) url(/Content/theme/slider-bkg.jpg) top center repeat-x; }
  .section.faq   { border-bottom: 1px solid var(--color-grey-border); }
  .section.doctors p { text-align: center; }

  .method-panels .expertise,
  .method-panels .food,
  .method-panels .care,
  .method-panels .better { background-position: 15px 20px; }

  .perex { background: var(--color-grey-border) url(/Content/theme/slider-bkg.jpg) bottom center repeat-x; padding: 0 25px; }
  .sgmap #subgurim_GMap1 { width: 940px !important; }

  /* Formulář */
  .form-inline.cc .form-group { display: inline-block !important; vertical-align: middle; margin-bottom: 0; }

  /* Shop */
  .shop h1                   { font-size: 2.5em; }
  .shopIntro .shopItem h3    { font-size: 1.3em; padding: 10px; }
  .customdetailnote p:nth-of-type(2) { width: 50% !important; }

  /* Cart */
  .formRow .fieldset {
    background: var(--color-white);
    margin: 0 15px 15px;
    width: 46.5%;
    padding: 15px;
  }
  .formRow .fieldset .btn-default { position: absolute; right: 15px; }

  /* Navbar */
  .dropdown-menu > li > a:hover,
  .dropdown-menu > li > a:focus    { background: var(--color-primary-dark) !important; color: var(--color-white) !important; }
  .navbar-default li li li a       { padding-left: 40px !important; }

  /* Download table */
  .dlThumb { width: 120px; }
  .dlSize  { width: 100px; }
  .dlDate  { width: 100px; }
}

/* ── TABLET PORTRAIT 768–991px ──────────────── */
@media (min-width: 768px) and (max-width: 991px) {
  header    { padding-top: 103px; }
  .container { width: 100%; }
  .header   { display: none; }
  .slides   { width: 100%; margin-bottom: 1em; }
  .aside    { display: none; }
  .motto    { display: none; }

  .navbar-brand img { height: 40px; position: relative; top: -10px; }
  .toplinks { padding: 5px 0; }
  .navbar   { margin-bottom: 0; }
  .bx-wrapper { border: 0; margin: 0 0 15px; }
  .htext1   { display: none; }
  .orderlink { text-align: right; }

  .slide-text > h1 {
    padding: 5px;
    text-shadow: none !important;
    color: var(--color-white);
    font-size: 25px;
    line-height: 34px;
    margin-bottom: 20px;
    letter-spacing: 0;
    animation-delay: 0.7s;
  }
  .slide-text > p,
  .slide-text > a { display: none; }

  .title-news .content { padding-top: 0; }

  /* Sekce */
  .section.exp,
  .section.faq  { padding: 15px 0; }
    .section.exp {
        background: var(--color-grey-border) url(/Content/theme/slider-bkg.jpg) top center repeat-x;
    }
  .section.faq  { border-bottom: 1px solid var(--color-grey-border); }
  .section.doctors p { text-align: center; }
  .method-panels .expertise,
  .method-panels .food,
  .method-panels .care,
  .method-panels .better { min-height: 70px; }

  .perex  { background: var(--color-grey-border) url(/Content/theme/slider-bkg.jpg) bottom center repeat-x; padding: 0 25px; }
  .sgmap  { display: none; }

  /* Formulář */
  .form-inline.cc .form-group { display: inline-block !important; vertical-align: middle; margin-bottom: 0; }
  .page-7 .textStatic table.table-responsive tr:first-child td { background: var(--color-grey-hover); font-weight: 600; }
  .page-7 .textStatic table.table-responsive tr td:first-child  { font-weight: 600; }

  /* Shop */
  .shopItem .itemFoto        { overflow: hidden; display: block; }
  .shopIntro .shopItem h3    { font-size: 1.5em; padding: 10px; }
  .itemAction                { position: absolute; top: 290px; left: 30px; }
  .customdetailnote p:nth-of-type(2) { width: 50% !important; }

  /* Cart */
  .formRow .fieldset {
    background: var(--color-white);
    margin: 0 15px 15px;
    padding: 15px;
  }
  .formRow .fieldset .btn-default { position: absolute; right: 15px; }

  /* Navbar */
  .dropdown-menu > li > a:hover,
  .dropdown-menu > li > a:focus    { background: var(--color-primary-dark) !important; color: var(--color-white) !important; }
  .navbar-default li li li a       { padding-left: 40px !important; }

  /* Slider */
  .slider {
    display: none;
    background: url(/Content/theme/slider-bkg.jpg) top center repeat-x;
    border-bottom: 1px solid var(--color-grey-border);
    max-height: 540px;
    overflow: hidden;
    height: 370px;
  }

  /* Download table */
  .dlThumb { width: 120px; }
  .dlSize  { width: 100px; }
  .dlDate  { width: 100px; }
}

/* ── MOBILNÍ LANDSCAPE 480–767px ────────────── */
@media (min-width: 480px) and (max-width: 767px) {
  header    { padding-top: 103px; }
  .header   { display: none; }
  .aside    { display: none; }
  .slides   { width: 100%; margin-bottom: 1em; }
  .h1       { font-size: 2.25em; margin-top: 0; }

  .slide-text > h1 {
    padding: 5px;
    text-shadow: none;
    color: var(--color-white);
    font-size: 25px;
    line-height: 34px;
    margin-bottom: 20px;
    letter-spacing: 0;
    animation-delay: 0.7s;
  }
  .slide-text > p,
  .slide-text > a { display: none; }

  .navbar-brand img { height: 40px; position: relative; top: -10px; }
  .toplinks  { padding: 5px 0; }
  .navbar    { margin-bottom: 0; }
  .bx-wrapper { border: 0; margin: 0 0 15px; }
  .htext1    { display: none; }
  .orderlink { text-align: right; }

  .footer-menu li { display: block; margin: 5px; }

  .motto .orderlink  { width: 100%; text-align: center; }
  .motto .siteSearch { width: 100%; margin-bottom: 15px; }
  .userInfo,
  #cartSum  { white-space: nowrap; }

  .intro-image { height: 300px !important; }
  .title-news .content { padding-top: 0; }
  .title .icons img { max-width: 64px; margin: 0 auto; }

  /* Tabulky */
  .textStatic table.table-responsive td,
  .textStatic table.table-responsive th { font-size: 14px; text-align: center; }
  .page-10 .textStatic table.table-responsive td,
  .page-10 .textStatic table.table-responsive th {
    display: block; border-bottom: 0; width: 100%;
    font-size: inherit; padding: 5px !important; text-align: left;
  }
  .page-10 .textStatic table.table-responsive tr { display: block; width: 100%; }

  /* Sekce */
  .perex { background: var(--color-grey-border) url(/Content/theme/slider-bkg.jpg) bottom center repeat-x; padding: 0 25px; }
  .sgmap { display: none; }
  .form-inline.cc .form-group { display: inline-block !important; vertical-align: middle; margin-bottom: 0; }

  /* Shop */
  .shopIntro .shopItem h3 { font-size: 1.5em; padding: 10px; }
  .itemAction             { position: absolute; top: 65%; left: 30px; }

  /* Navbar */
  .dropdown-menu > li > a:hover,
  .dropdown-menu > li > a:focus    { background: var(--color-primary-dark) !important; color: var(--color-white) !important; }
  .navbar-default li li li a       { padding-left: 40px !important; }

  /* Download table */
  .dlThumb { width: 120px; }
  .dlSize  { width: 80px !important; }
  .dlDate  { width: 100px; }

  /* Cart */
  .formRow .fieldset {
    background: var(--color-white);
    margin: 0 15px 15px;
    padding: 15px;
  }
  .formRow .fieldset .btn-default { position: absolute; right: 15px; }

  /* Slider */
  .slider {
    display: none;
    background: url(/Content/theme/slider-bkg.jpg) top center repeat-x;
    border-bottom: 1px solid var(--color-grey-border);
    overflow: hidden;
    max-height: 300px;
  }

  /* Wizard – střední breakpoint */
  #wizHeader {
    list-style: none; overflow: hidden;
    font-size: 1em; font-weight: 400;
    margin: 0 0 20px; padding: 0;
  }
  #wizHeader li { float: left; }
  #wizHeader li a {
    color: var(--color-white); text-decoration: none;
    padding: 10px 0 10px 35px;
    background: hsla(134, 85%, 35%, 1);
    position: relative; display: block; float: left;
    font-family: 'Open Sans Condensed';
  }
  #wizHeader li a::after {
    content: ""; display: block; width: 0; height: 0;
    border-top: 50px solid transparent;
    border-bottom: 50px solid transparent;
    border-left: 30px solid hsla(34, 85%, 35%, 1);
    position: absolute; top: 50%; left: 100%;
    margin-top: -50px; z-index: 2;
  }
  #wizHeader li a::before {
    content: ""; display: block; width: 0; height: 0;
    border-top: 50px solid transparent;
    border-bottom: 50px solid transparent;
    border-left: 30px solid var(--color-white);
    position: absolute; top: 50%; left: 100%;
    margin-top: -50px; margin-left: 1px; z-index: 1;
  }
}

/* ── MALÝ MOBIL 361–479px ───────────────────── */
@media (min-width: 361px) and (max-width: 479px) {
  header   { padding-top: 123px; }
  .header  { display: none; }
  .aside   { display: none; }
  .motto   { display: none; }
  .slides  { width: 100%; margin-bottom: 1em; }

  .slide-text > h1 {
    padding: 0 5px;
    text-shadow: none !important;
    color: var(--color-white);
    font-size: 18px;
    line-height: 34px;
    margin-bottom: 20px;
    letter-spacing: 0;
    animation-delay: 0.7s;
  }
  .slide-text > p,
  .slide-text > a { display: none; }

  .navbar-brand img { height: 30px; position: relative; top: -5px; }
  .toplinks { padding: 5px 0; font-size: 15px; }
  .toplinks span { margin: 0 5px; }
  .toplinks .col-xs-3 { width: 30% !important; }
  .toplinks .col-xs-9 { width: 70% !important; }
  .navbar   { margin-bottom: 0; }
  .bx-wrapper { border: 0; margin: 0 0 15px; }
  .htext1   { display: none; }
  .orderlink { text-align: right; }

  .motto .orderlink  { width: 100%; text-align: center; }
  .motto .siteSearch { width: 100%; margin-bottom: 15px; }
  #cartSum  { white-space: nowrap; }
  .userInfo,
  #cartSum  { white-space: nowrap; width: 100% !important; }

  .footer-menu li { display: block; margin: 5px; }
  .title .icons img { max-width: 64px; margin: 0 auto; }
  .table-contact td { padding-bottom: 30px !important; }

  /* Navbar */
  .dropdown-menu > li > a:hover,
  .dropdown-menu > li > a:focus    { background: var(--color-primary-dark) !important; color: var(--color-white) !important; }
  .navbar-default li li li a       { padding-left: 40px !important; }

  /* Sekce */
  .perex { background: var(--color-grey-border) url(/Content/theme/slider-bkg.jpg) bottom center repeat-x; padding: 0 25px; }
  .perex .btn { margin-bottom: 15px; }
  .sgmap  { display: none; }
  .form-inline.cc .form-group { display: inline-block !important; vertical-align: middle; margin-bottom: 0; }
  .form-inline.cc .btn { margin: 0 15px; }

  .intro-image { height: 200px !important; }
  .h1          { font-size: 1.75em; margin-top: 0; }

  /* Tabulky */
  .page-10 .textStatic table.table-responsive td,
  .page-10 .textStatic table.table-responsive th {
    display: block; border-bottom: 0; width: 100%;
    font-size: inherit; padding: 5px !important;
  }
  .page-10 .textStatic table.table-responsive tr { display: block; width: 100%; }
  .textStatic table.table-responsive td,
  .textStatic table.table-responsive th { font-size: 12px; padding: 3px !important; }

  .content a.fancybox     { display: block; }
  .content a.fancybox img { width: 100% !important; height: auto !important; }

  /* Download table */
  .downloadTable td,
  .downloadTable th       { display: block; width: 100%; text-align: left; }
  .downloadTable th       { border-bottom: 1px solid var(--color-black) !important; }
  .downloadTable th:last-child { border: none !important; }
  .downloadTable td       { border-color: transparent !important; }
  .downloadTable td:first-child { border-top: 1px solid var(--color-black) !important; font-weight: 600; }

  /* Layout */
  .content p, .content h2, .content h3,
  .content h4, .h1 { padding-left: 0; padding-right: 0; }
  .display { margin-bottom: 50px !important; }
  .galBody .col-xs-2 { width: 50% !important; }

  /* Shop */
  .shopIntro .shopItem h3            { width: 90%; font-size: 1.5em; padding: 15px; }
  .shopIntro .shopItem.col-xs-4      { width: 100%; }
  .shopItem.col-xs-6                 { width: 50%; }
  .itemAction                        { position: absolute; top: 305px; left: 30px; }
  .spinner                           { width: 131px; }

  /* Cart */
  .cartList tr,
  .cartList td { display: block; width: 100% !important; border-top: none !important; }
  .AspNet-GridView-Alternate td { background: var(--color-grey-hover); }
  .formRow .fieldset {
    background: var(--color-white);
    margin: 0 15px 15px;
    padding: 15px;
  }
  .formRow .fieldset .btn-default { position: absolute; right: 15px; }

  /* Wizard – malý breakpoint (zjednodušený, bez šipek) */
  #wizHeader {
    list-style: none; overflow: hidden;
    font-size: 1em; font-weight: 400;
    margin: 0 0 20px; padding: 0;
  }
  #wizHeader li { float: left; }
  #wizHeader li a {
    color: var(--color-white); text-decoration: none;
    padding: 5px 8px;
    background: hsla(134, 85%, 35%, 1);
    position: relative; display: block; float: left;
    font-family: 'Open Sans Condensed';
    border-right: 1px solid var(--color-white);
  }
  #wizHeader li a::after,
  #wizHeader li a::before { content: none; }
}

/* ── NEJMENŠÍ MOBIL ≤ 360px ─────────────────── */
@media (max-width: 360px) {
  header   { padding-top: 115px; }
  .header  { display: none; }
  .aside   { display: none; }
  .motto   { display: none; }
  .slides  { width: 100%; margin-bottom: 1em; }

  .slide-text { top: 0; padding: 10px 20px; }
  .slide-text > h1 {
    padding: 0 5px;
    text-shadow: none !important;
    color: var(--color-white);
    font-size: 18px;
    line-height: 34px;
    margin-bottom: 20px;
    letter-spacing: 0;
    animation-delay: 0.7s;
  }
  .slide-text > p,
  .slide-text > a { display: none; }

  .h1 { font-size: 1.55em !important; }
  .toplinks { padding: 5px 0; font-size: 15px; }
  .toplinks span { margin: 0 5px; }
  .toplinks .col-xs-3 { width: 30% !important; }
  .toplinks .col-xs-9 { width: 70% !important; }
  .navbar   { margin-bottom: 0; }
  .bx-wrapper { border: 0; margin: 0 0 15px; }
  .htext1   { display: none; }
  .orderlink { text-align: right; }
  .logo-image { font-size: 1.25em; }

  .motto .orderlink  { width: 100%; text-align: center; }
  .motto .siteSearch { width: 100%; margin-bottom: 15px; }
  #cartSum  { white-space: nowrap; }

  .intro-image  { height: 200px !important; }
  .footer-menu li { display: block; margin: 5px; }
  .title .icons img { max-width: 64px; margin: 0 auto; }
  .table-contact td { padding-bottom: 30px !important; }
  .display { margin-bottom: 60px !important; }

  /* Navbar */
  .dropdown-menu > li > a:hover,
  .dropdown-menu > li > a:focus    { background: var(--color-primary-dark) !important; color: var(--color-white) !important; }
  .navbar-default li li li a       { padding-left: 40px !important; }

  /* Sekce */
    .perex {
        background: var(--color-primary-dark) url(/Content/theme/slider-bkg.jpg) bottom center repeat-x;
        padding: 0 25px;
    }
  .perex .btn { margin-bottom: 15px; }
  .sgmap  { display: none; }
  .form-inline.cc .form-group { display: inline-block !important; vertical-align: middle; margin-bottom: 0; }
  .form-inline.cc .btn { margin: 0 15px; }

  /* Layout */
  .content p, .content h2, .content h3,
  .content h4, .h1 { padding-left: 0; padding-right: 0; }
  .col-xs-6 { width: 100% !important; }
  .thumbnail h3 { height: auto !important; }

  /* Tabulky */
  .textStatic table.table-responsive td,
  .textStatic table.table-responsive th { font-size: 12px; padding: 3px !important; }
  .page-10 .textStatic table.table-responsive td,
  .page-10 .textStatic table.table-responsive th {
    display: block; border-bottom: 0; width: 100%;
    font-size: inherit; padding: 5px !important;
  }
  .page-10 .textStatic table.table-responsive tr { display: block; width: 100%; }

  .content a.fancybox     { display: block; }
  .content a.fancybox img { width: 100% !important; height: auto !important; }

  /* Download table */
  .downloadTable td,
  .downloadTable th       { display: block; width: 100%; text-align: left; }
  .downloadTable th       { border-bottom: 1px solid var(--color-black) !important; }
  .downloadTable th:last-child { border: none !important; }
  .downloadTable td       { border-color: transparent !important; }
  .downloadTable td:first-child { border-top: 1px solid var(--color-black) !important; font-weight: 600; }

  /* Shop */
  .shopIntro .shopItem h3       { width: 90%; font-size: 1.5em; padding: 15px; }
  .shopIntro .shopItem.col-xs-4 { width: 100%; }
  .shopItem.col-xs-6            { width: 50%; }
  .itemAction                   { position: absolute; top: 69%; left: 30px; }
  .shopItem .spinner            { width: 131px; }

  /* Cart */
  .cartList tr,
  .cartList td { display: block; width: 100% !important; border-top: none !important; }
  .AspNet-GridView-Alternate td { background: var(--color-grey-hover); }
  .formRow .fieldset {
    background: var(--color-white);
    margin: 0 15px 15px;
    padding: 15px;
  }
  .formRow .fieldset .btn-default { position: absolute; right: 15px; }
}

/* =====================
   SIDEBAR NAV
   ===================== */
.nav-side-menu {
    font-family: verdana;
    font-size: 12px;
    font-weight: 200;
    background-color: var(--color-white);
    position: relative;
    top: 15px;
    height: 100%;
    margin: 15px 0 30px !important;
    border: 1px solid var(--color-grey-border);
}

.nav-side-menu .brand {
  display: block;
  padding: 5px 10px;
  font-size: 1.5em;
  font-family: "Open Sans Condensed";
  font-weight: 700;
  color: var(--color-black);
  border-radius: 5px 5px 0 0;
}

.nav-side-menu .toggle-btn {
  display: none;
  border-radius: 5px;
}

.nav-side-menu ul,
.nav-side-menu li {
  list-style: none;
  padding: 0;
  margin: 0;
  line-height: 2em;
  cursor: pointer;
}

/* Šipka rozbalovacího menu */
.nav-side-menu ul :not(collapsed) .arrow::before,
.nav-side-menu li :not(collapsed) .arrow::before {
  font-family: FontAwesome;
  content: "\f078";
  display: inline-block;
  padding: 0 10px;
  vertical-align: middle;
  float: right;
}

/* Podsekce */
.nav-side-menu ul .sub-menu li,
.nav-side-menu li .sub-menu li {
  background-color: var(--color-white);
  color: var(--color-black);
  border: none;
  line-height: 28px;
}

/* Ikona před položkou */
.nav-side-menu > ul li span::before {
  font-family: FontAwesome;
  content: "\f105";
  display: inline-block;
  padding-right: 5px;
  vertical-align: middle;
}

.nav-side-menu li {
  padding-left: 0;
  border: none;
}

.nav-side-menu li a {
  font-family: "Open Sans", sans-serif;
  font-weight: 400;
  font-size: 1em;
  display: block;
  padding: .5em 0;
  text-decoration: none;
  line-height: 1em;
}

.nav-side-menu li a i { padding: 0 20px 0 10px; width: 20px; }

.nav-side-menu li > a::before {
  font-family: FontAwesome;
  content: "\f105";
  padding-right: 5px;
  font-weight: 700;
}

.nav-side-menu li li > a         { color: var(--color-primary); }
.nav-side-menu li li > a::before { content: ''; }

.nav-side-menu li:last-child a            { border: none; }
.nav-side-menu .sub-menu li:last-child a  { border-bottom: none; }
.nav-side-menu li > a:hover,
.nav-side-menu li > a:hover { color: var(--color-primary-dark); }

.nav-side-menu ul { margin: 0; padding: 0 0 0 15px; list-style: none; }
.nav-side-menu li.active > a { color: var(--color-primary-dark); font-weight: 600;
}

/* Sidebar – desktop ≥ 1200px */
@media (min-width: 1200px) {
  .nav-side-menu {
    border-radius: 0 !important;
    font-size: 12px;
    font-weight: 200;
    position: relative;
    top: 0;
    height: 100%;
    color: var(--color-black);
    padding: 10px 0;
  }
  .nav-side-menu .menu-list .menu-content { display: block; }
  .nav-side-menu .brand        { border-radius: 5px 5px 0 0 !important; }
  .nav-side-menu .panel-shop   { display: none; }
}

/* Sidebar – tablet ≤ 1199px */
@media (max-width: 1199px) {
  .nav-side-menu {
    position: relative;
    width: 100%;
    margin-bottom: 10px;
    border: 1px solid var(--color-grey-border);
  }
  .nav-side-menu .toggle-btn {
    display: block;
    cursor: pointer;
    position: absolute;
    right: 10px;
    top: 10px;
    z-index: 10 !important;
    padding: 3px;
    background-color: var(--color-white);
    color: var(--color-black);
    width: 40px;
    text-align: center;
  }
  .nav-side-menu .brand {
    text-align: left !important;
    font-size: 1.5em !important;
    line-height: 42px !important;
    border-radius: 5px;
  }
  .nav-side-menu a { font-size: 1.25em; padding: 0 5px; border-bottom: 1px solid var(--color-grey-border); }
  .nav-side-menu .sub-menu li:last-child a { border-bottom: 1px solid var(--color-grey-border); }
}

/* Sidebar – mobil ≤ 767px */
@media (max-width: 767px) {
  .nav-side-menu {
    border-radius: 0;
    border: none;
    border-top: 1px solid var(--color-grey-border);
    border-bottom: 1px solid var(--color-grey-border);
  }
  .nav-side-menu .brand { border-radius: 0; }
}