/* Landing page responsive fixes to keep the public site close to the original demo on tablet/mobile */

.landing-demo-shell .main-banner .item,
.landing-demo-shell .events_item,
.landing-demo-shell .team-member,
.landing-demo-shell .service-item,
.landing-demo-shell .about-us .accordion,
.landing-demo-shell .about-us .section-heading {
  box-sizing: border-box;
}

.landing-demo-shell .courses .event_filter {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}

.landing-demo-shell .courses .event_filter li {
  margin: 0;
}

.landing-demo-shell .courses .event_box {
  row-gap: 30px;
}

.landing-demo-shell .landing-course-card .events_item,
.landing-demo-shell .landing-team-card .team-member {
  height: 100%;
}

.landing-demo-shell .landing-course-card .thumb img {
  width: 100%;
  height: 250px;
  object-fit: cover;
  display: block;
}

.landing-demo-shell .landing-team-card .team-member img {
  width: 170px;
  height: 170px;
  object-fit: cover;
}

.landing-demo-shell .landing-course-card .down-content {
  min-height: 120px;
}

.landing-demo-shell .landing-course-card .down-content h4,
.landing-demo-shell .landing-team-card .main-content h4 {
  word-break: break-word;
}

.landing-demo-shell .team .row {
  row-gap: 30px;
}

.landing-demo-shell .team-member {
  margin-bottom: 0;
}

@media (max-width: 1199.98px) {
  .landing-demo-shell .main-banner .item {
    margin-left: 0;
    padding: 100px 56px 140px;
  }

  .landing-demo-shell .main-banner .item h2 {
    font-size: 40px;
    line-height: 1.25;
  }

  .landing-demo-shell .landing-course-card .thumb img {
    height: 230px;
  }
}

@media (max-width: 991.98px) {
  .landing-demo-shell .main-banner {
    padding-top: 100px;
  }

  .landing-demo-shell .main-banner .item {
    margin-left: 0;
    text-align: center;
    padding: 96px 40px 132px;
  }

  .landing-demo-shell .main-banner .item h2,
  .landing-demo-shell .main-banner .item p {
    width: 100%;
    max-width: none;
  }

  .landing-demo-shell .main-banner .item h2 {
    font-size: 34px;
    line-height: 1.35;
  }

  .landing-demo-shell .main-banner .item .buttons {
    justify-content: center;
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
  }

  .landing-demo-shell .services {
    margin-top: 80px;
  }

  .landing-demo-shell .about-us {
    margin-top: 100px;
  }

  .landing-demo-shell .about-us .section-heading {
    margin-top: 72px;
    margin-left: 0;
    text-align: center;
  }

  .landing-demo-shell .courses {
    margin-top: 100px;
  }

  .landing-demo-shell .section-heading h2 {
    font-size: 32px;
    line-height: 1.3;
  }

  .landing-demo-shell .landing-course-card .thumb img {
    height: 220px;
  }

  .landing-demo-shell .landing-team-card .team-member {
    margin-top: 86px;
  }

  .landing-demo-shell .landing-team-card .team-member img {
    width: 150px;
    height: 150px;
  }
}

@media (max-width: 767.98px) {
  .landing-demo-shell .main-banner {
    padding-top: 84px;
  }

  .landing-demo-shell .main-banner .item {
    padding: 76px 22px 112px !important;
    border-radius: 28px;
  }

  .landing-demo-shell .main-banner .item span.category {
    font-size: 12px;
    padding: 8px 16px;
  }

  .landing-demo-shell .main-banner .item h2 {
    font-size: 28px;
    line-height: 1.35;
    margin-bottom: 18px;
  }

  .landing-demo-shell .main-banner .item p {
    font-size: 14px;
    line-height: 1.8;
  }

  .landing-demo-shell .main-banner .owl-nav {
    left: 30px !important;
    transform: none !important;
    bottom: 38px;
  }

  .landing-demo-shell .section-heading h2 {
    font-size: 28px;
  }

  .landing-demo-shell .section-heading h6 {
    font-size: 12px;
  }

  .landing-demo-shell .courses .event_filter {
    gap: 10px;
    padding: 15px 14px;
  }

  .landing-demo-shell .courses .event_filter a {
    font-size: 13px;
    padding: 8px 16px;
  }

  .landing-demo-shell .landing-course-card .thumb img {
    height: 210px;
  }

  .landing-demo-shell .landing-course-card .events_item .down-content {
    padding: 26px 22px 24px;
    min-height: auto;
  }

  .landing-demo-shell .landing-course-card .events_item .down-content h4 {
    font-size: 18px;
    line-height: 1.4;
  }

  .landing-demo-shell .landing-team-card .team-member {
    margin-top: 78px;
  }

  .landing-demo-shell .landing-team-card .team-member .main-content {
    padding: 88px 24px 28px;
  }

  .landing-demo-shell .landing-team-card .team-member img {
    width: 136px;
    height: 136px;
    margin-top: -68px;
  }

  .landing-demo-shell .landing-team-card .main-content h4 {
    font-size: 20px;
  }

  .landing-demo-shell .landing-team-card .main-content span.category {
    font-size: 13px;
  }
}


/* Breadcrumb */
.app-breadcrumb-wrap {
  margin-bottom: 1.25rem;
}

.app-breadcrumb {
  margin: 0;
  padding: 12px 18px;
  border-radius: 999px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(201, 162, 74, 0.22);
  box-shadow: 0 10px 26px rgba(0,0,0,0.06);
  backdrop-filter: blur(8px);
}

.app-breadcrumb .breadcrumb-item,
.app-breadcrumb .breadcrumb-item span,
.app-breadcrumb .breadcrumb-item.active {
  color: var(--color-text-muted, #6b7280);
  font-size: 0.95rem;
  font-weight: 500;
}

.app-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
  color: var(--color-primary);
  font-weight: 700;
}

.app-breadcrumb .breadcrumb-item a {
  color: var(--color-primary) !important;
  text-decoration: none;
  transition: color .2s ease, opacity .2s ease;
}

.app-breadcrumb .breadcrumb-item a:hover {
  color: var(--color-primary-dark, var(--color-primary)) !important;
  opacity: 0.85;
}

.app-breadcrumb .breadcrumb-item.active span {
  color: var(--color-text-main, #1f2937);
  font-weight: 700;
}

[data-bs-theme=dark] .app-breadcrumb {
  background: rgba(27, 35, 53, 0.82);
  border-color: rgba(255,255,255,0.08);
}

@media (max-width: 767.98px) {
  .app-breadcrumb {
    padding: 10px 14px;
    border-radius: 18px;
  }

  .app-breadcrumb .breadcrumb-item,
  .app-breadcrumb .breadcrumb-item span,
  .app-breadcrumb .breadcrumb-item.active {
    font-size: 0.84rem;
  }
}

/* Public header + landing page final responsive tuning */
.public-site-header {
  top: 24px;
}
.public-site-header .main-nav {
  align-items: center;
  width: 100%;
}
.public-site-header .main-nav > .nav {
  display: flex;
  align-items: center;
  gap: 6px;
}
.public-site-header .main-nav > .nav > li {
  display: inline-flex;
  align-items: center;
}
.public-site-header .main-nav > .nav > li > a {
  white-space: nowrap;
}
.public-site-header .theme-switcher a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
}

html[dir="rtl"] .app-breadcrumb {
  direction: rtl;
  justify-content: flex-start;
}
html[dir="rtl"] .app-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
  float: right;
  padding-right: 0;
  padding-left: .5rem;
}
html[dir="rtl"] .app-breadcrumb .breadcrumb-item {
  display: inline-flex;
  align-items: center;
}

@media (max-width: 1199.98px) {
  .public-site-header {
    top: 0;
  }
  .public-site-header .main-nav {
    min-height: 82px;
  }
  .public-site-header .main-nav .logo h1 {
    font-size: 28px;
    border-right: 0;
    padding-right: 0;
    margin-right: 0;
  }
  .public-site-header .main-nav > .nav {
    top: calc(100% + 8px);
    padding: 14px;
    border-radius: 28px;
    background: rgba(122,106,216,.98);
  }
  .public-site-header .main-nav > .nav > li > a {
    width: 100%;
    justify-content: center;
    height: 48px;
    line-height: 48px;
  }
}

@media (max-width: 991.98px) {
  .landing-demo-shell .main-banner {
    padding-top: 96px;
  }
  .landing-demo-shell .main-banner .container,
  .landing-demo-shell .services .container,
  .landing-demo-shell .courses .container,
  .landing-demo-shell .team .container,
  .landing-demo-shell .about-us .container {
    padding-left: 20px;
    padding-right: 20px;
  }
  .landing-demo-shell .main-banner .item {
    padding: 88px 36px 126px;
  }
}

@media (max-width: 767.98px) {
  .public-site-header .main-nav {
    min-height: 74px;
  }
  .public-site-header .main-nav .logo h1 {
    font-size: 24px;
  }
  .public-site-header .menu-trigger {
    top: 18px;
  }
  .landing-demo-shell .main-banner {
    padding-top: 82px;
  }
  .landing-demo-shell .main-banner .container,
  .landing-demo-shell .services .container,
  .landing-demo-shell .courses .container,
  .landing-demo-shell .team .container,
  .landing-demo-shell .about-us .container {
    padding-left: 14px;
    padding-right: 14px;
  }
  .landing-demo-shell .main-banner .item {
    padding: 68px 18px 104px !important;
  }
  .landing-demo-shell .main-banner .item h2 {
    font-size: 24px;
  }
  .landing-demo-shell .services {
    margin-top: 60px;
  }
  .landing-demo-shell .about-us,
  .landing-demo-shell .courses,
  .landing-demo-shell .team {
    margin-top: 80px;
  }
  .landing-demo-shell .landing-course-card .thumb img {
    height: 190px;
  }
  .landing-demo-shell .landing-team-card .team-member .main-content {
    padding-left: 18px;
    padding-right: 18px;
  }
}


/* Publish polish: public topbar based on dashboard topbar */
.public-topbar {
  position: sticky;
  top: 0;
  z-index: 1040;
}
.public-topbar .brand-link {
  min-width: max-content;
}
.public-topbar .brand-copy small,
.public-topbar .brand-copy strong {
  line-height: 1.15;
}
.public-topbar .brand-copy small {
  text-transform: uppercase;
  letter-spacing: .08em;
}
.public-topnav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}
.public-topnav a,
.public-topnav .public-topnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 0px solid var(--color-border-soft);
  background: transparent;
  color: var(--color-heading);
  text-decoration: none;
  font-weight: 500;
  /*box-shadow: var(--bs-box-shadow-sm);*/
  transition: .2s ease;
}
    .public-topnav a:hover,
    .public-topnav .public-topnav-link:hover {
        border: 0.5px solid var(--color-border-soft);
        border-color: var(--color-primary-border);
        color: var(--color-primary-dark);
        box-shadow: var(--bs-box-shadow-sm);
        transform: translateY(-1px);
    }
.public-topnav .danger {
  color: #b42318;
  background: color-mix(in srgb, #fff 92%, #fef3f2);
}
.public-topnav .danger:hover {
  color: #912018;
  border-color: rgba(180,35,24,.24);
}
.public-topnav button {
  appearance: none;
  cursor: pointer;
}
html[dir="rtl"] .app-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row-reverse;
  justify-content: flex-end;
}
html[dir="rtl"] .app-breadcrumb .breadcrumb-item {
  display: inline-flex;
  align-items: center;
}
html[dir="rtl"] .app-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
  float: none;
  padding-left: 0;
  padding-right: .5rem;
}
@media (max-width: 991.98px) {
  .public-topbar .container-fluid {
    padding-left: 16px;
    padding-right: 16px;
  }
  .public-topbar-row {
    justify-content: center !important;
  }
  .public-topnav {
    width: 100%;
    justify-content: center;
    gap: 8px;
  }
}
@media (max-width: 767.98px) {
  .public-topnav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .public-topnav a,
  .public-topnav .public-topnav-link {
    width: 100%;
    min-height: 44px;
    padding: 10px 12px;
    font-size: 14px;
  }
}


.app-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .35rem;
}

.app-breadcrumb.rtl {
  justify-content: flex-start;
}

.app-breadcrumb .breadcrumb-item,
.app-breadcrumb .breadcrumb-separator {
  float: none;
  display: inline-flex;
  align-items: center;
  line-height: 1.2;
}

.app-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
  content: none !important;
}

.app-breadcrumb .breadcrumb-separator {
  color: var(--color-primary);
  font-weight: 700;
  padding-inline: .15rem;
  flex: 0 0 auto;
}

.app-breadcrumb.rtl .breadcrumb-separator span {
  display: inline-block;
  transform: scaleX(-1);
}

.auth-image-hero {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.auth-hero-visual {
  margin-top: 1rem;
  border-radius: 24px;
  overflow: hidden;
  min-height: 420px;
  box-shadow: 0 18px 40px rgba(0,0,0,.18);
  background: rgba(255,255,255,0.08);
}

.auth-hero-visual img {
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
  display: block;
}

@media (max-width: 767.98px) {
  .auth-hero-visual,
  .auth-hero-visual img {
    min-height: 280px;
  }
}


/* v5 public header collapse + theme toggle */
.public-topbar {
  position: sticky;
  top: 0;
  z-index: 1045;
}

.public-topbar-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
}

.public-topbar-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.public-menu-toggle,
.public-theme-toggle {
  border: 1px solid var(--color-border-soft);
}

.public-topnav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

@media (min-width: 992px) {
  .public-menu-toggle {
    display: none !important;
  }
}

@media (max-width: 991.98px) {
  .public-topbar {
    background: color-mix(in srgb, var(--color-surface-elevated) 94%, transparent) !important;
  }

  .public-topbar-row {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "brand actions"
      "menu menu";
    align-items: center;
  }

  .public-topbar-row .brand-link {
    grid-area: brand;
    min-width: 0;
  }

  .public-topbar-actions {
    grid-area: actions;
  }

  .public-topnav {
    grid-area: menu;
    display: none;
    margin-top: 6px;
    padding: 12px;
    border-radius: 24px;
    background: color-mix(in srgb, var(--color-surface-elevated) 96%, transparent);
    border: 1px solid var(--color-border-soft);
    box-shadow: 0 18px 40px var(--color-shadow-soft);
    width: 100%;
    justify-content: stretch;
    gap: 10px;
  }

  .public-topnav.is-open {
    display: grid;
    grid-template-columns: 1fr;
  }

  .public-topnav a,
  .public-topnav .public-topnav-link,
  .public-topnav button {
    width: 100%;
    min-height: 46px;
  }
}

@media (max-width: 767.98px) {
  .public-topbar .container-fluid {
    padding-left: 14px;
    padding-right: 14px;
  }

  .public-topbar-row {
    gap: 12px;
  }

  .public-topbar .brand-copy strong {
    font-size: 15px;
  }

  .public-topbar .brand-copy small {
    font-size: 11px;
  }

  .public-topnav {
    padding: 10px;
    border-radius: 20px;
  }
}
