/*
* custom.css
******************************************************************************/

.menu .app-brand.logo-title {
  height: 64px;
  margin-top: 12px;
}

.app-brand-logo.logo-title svg {
  width: 22px;
  height: 38px;
}

.app-brand-text.logo-title {
  font-size: 1.75rem;
  letter-spacing: -0.5px;
}

/* ! For .layout-navbar-fixed added fix padding top to .layout-page */
/* Detached navbar */
.layout-navbar-fixed .layout-wrapper:not(.layout-horizontal):not(.layout-without-menu) .layout-page {
  padding-top: 74px !important;
}
/* Default navbar */
.layout-navbar-fixed .layout-wrapper:not(.layout-without-menu) .layout-page {
  padding-top: 64px !important;
}
.docs-page .layout-navbar-fixed.layout-wrapper:not(.layout-without-menu) .layout-page,
.docs-page .layout-menu-fixed.layout-wrapper:not(.layout-without-menu) .layout-page {
  padding-top: 62px !important;
}

/* Navbar page z-index issue solution */
.content-wrapper .navbar {
  z-index: auto;
}

/*
* Font
******************************************************************************/

/* Modovisa Regular */
@font-face {
    font-family: 'Modovisa';
    src: url('fonts/Modovisa-Regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

/* Modovisa Medium */
@font-face {
    font-family: 'Modovisa';
    src: url('fonts/Modovisa-Medium.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

/* Modovisa DemiBold */
@font-face {
    font-family: 'Modovisa';
    src: url('fonts/Modovisa-SemiBold.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

/* Modovisa Bold */
@font-face {
    font-family: 'Modovisa';
    src: url('fonts/Modovisa-Bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

/* Modovisa ExtraBold */
@font-face {
    font-family: 'Modovisa';
    src: url('fonts/Modovisa-ExtraBold.woff2') format('woff2');
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}

/* Override FA webfont with font-display */
@font-face {
  font-family: "Font Awesome 6 Free";
  src: url("/assets/vendor/fonts/fontawesome/fa-solid-900.woff2") format("woff2");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Font Awesome 6 Brands";
  src: url("/assets/vendor/fonts/fontawesome/fa-brands-400.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}


:root,
[data-bs-theme=light] {
--bs-body-font-family: 'Modovisa', -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;
--bs-font-sans-serif: 'Modovisa', sans-serif; /* Optional, for consistency */
--bs-root-font-size: 17px;
}

/*
* Customisations
******************************************************************************/

nav.layout-navbar .navbar.landing-navbar {
  border: none !important;
  padding-block: 0.8rem !important;
  border-radius: 0.5rem !important;
}

nav.layout-navbar .navbar.landing-navbar .navbar-nav .nav-link:hover {
  color: #586d7f !important;
}

@media (max-width: 767.98px) {
    .dropdown-menu-responsive {
        position: relative !important;
    }
}

@media (max-width: 1199.98px) {
    .dropdown-menu-responsive {
        position: relative !important;
    }
}

/* Default (desktop) */
.logo-img {
  width: 200px;
  height: auto;
}

/* Mobile breakpoint */
@media (max-width: 575.98px) {
  .logo-img {
    width: 160px;
  }
}

.hero-text-box-wrapper {
    background-color: rgba(255, 255, 255, 0.51);
    margin-block: 0;
    margin-inline: auto;
    max-inline-size: 55em;
    padding: 35px;
    border-radius: 20px 130px 20px 130px;
}

.landing-hero {
  border-radius: 0px !important;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
}

@media (min-width: 992px) {
    .landing-hero .hero-text-box {
        max-inline-size: 55rem !important;
    }
  }

.gradient-canvas {
    --gradient-color-1: #a960ee;
    --gradient-color-2: #ff333d;
    --gradient-color-3: #90e0ff;
    --gradient-color-4: #ffcb57;
    position: absolute;
    top: 0;
    left: 0;
    }

#landingHero {background: transparent;}

.hero-text-box {
    background: #fff;
    padding: 50px;
    border-radius: 20px 100px 20px 100px;
    box-shadow: rgba(0, 0, 0, 0.15) 0px 5px 15px 0px;
  }

.gradient-word {
  display: inline-block;
  background: linear-gradient(
    135deg,
    #90e0ff 0%,
    #ff333d 33%,
    #ffcb57 66%,
    #a960ee 100% 
  );
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-size: 200% auto;
  animation: shine 7s ease-in-out infinite alternate;
  font-size: calc(1.6rem + 2.8vw);
  line-height: 1.2;
}

.gradient-word-subtitle {
  display: inline-block;
  background: linear-gradient(
    135deg,
    #3a0d93 0%,
    #384551 33%,
    #3a0d93 66%,
    #384551 100%  
  );
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-size: 200% auto;
  animation: shine 4s ease-in-out infinite alternate;
}

.landing-features .features-icon-wrapper
{
  box-shadow: rgba(17, 17, 26, 0.05) 0px 1px 0px, rgba(17, 17, 26, 0.15) 0px 4px 12px;
  border-radius: 20px;
  padding-bottom: 5rem !important;
}

@keyframes shine {
  0% {
    background-position: 0% center;
  }
  100% {
    background-position: 200% center;
  }
}

.landing-hero-btn .btn-primary {
    background-color: #2872fa;
    border-color: #2872fa;
    
}

.landing-hero-btn .btn-primary:hover {
    background-color: #1559ed;
}

.hero-dashboard-img-static {
  max-width: 1200px;
  width: 100%;
}

.animation-img {
  width: 100%;
  height: auto;
  display: block;
}

/*
* Integrations - Scroller
**************/

.integrations-text-wrapper {
  border-radius: 20px;
  box-shadow: rgba(0, 0, 0, 0.16) 0px 10px 36px 0px, rgba(0, 0, 0, 0.06) 0px 0px 0px 1px;
}

.integration-scroller {
  height: 120px; /* Set container height */
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
  background: #fff;
  display: flex;
  align-items: center; /* vertically center logos */
}

.scroll-track {
  animation: scrollLoop 35s linear infinite;
  display: flex;
  width: max-content;
  gap: 100px; /* Set desired spacing between logos */
  align-items: center; /* already present */
}

.integration-logo img {
  width: 200px;
  height: 72px;
  object-fit: contain;
  flex-shrink: 0;
  opacity: 0.8;
  transition: opacity 0.3s ease;
}

.integration-logo:hover {
  opacity: 1;
}

@keyframes scrollLoop {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

/*
* Footer
**************/

.landing-footer .footer-top {
  border-radius: 50px;
  border-top-left-radius: 50px !important;
  border-top-right-radius: 50px !important;
  box-shadow: rgba(17, 17, 26, 0.05) 0px 1px 0px, rgba(17, 17, 26, 0.15) 0px 4px 12px;
}

/*
* Legal Pages
**************/

.legal-wrapper {
  box-shadow: rgba(17, 17, 26, 0.05) 0px 1px 0px, rgba(17, 17, 26, 0.15) 0px 4px 12px;
  border-radius: 30px;
}

.legal-wrapper h2 {
  line-height: 2.5rem !important;
}

/*
* Live Tracking CSS
**************/

.bg-visitor-page-inactive {
  background-color: color-mix(in sRGB, var(--bs-base-color) 6%, var(--bs-paper-bg));
}

.pulse {
  animation: pulse-animation 2s infinite;
  border-radius: 10px;
}

@keyframes pulse-animation {
  0% {
    box-shadow: 0 0 0 0px rgba(0, 0, 0, 0.15);
  }
  100% {
    box-shadow: 0 0 0 15px rgba(0, 0, 0, 0);
  }
}

.avatar-online i {
  font-size: 38px;
}

.app-live-visitor-tracking .app-live-visitor-tracking-sidebar {
  flex-basis: 20rem !important;
}

.live-visitor-tracking-filter-folders .active {
  background-color: #fff;
  box-shadow: rgba(17, 17, 26, 0.1) 0px 1px 0px;
  border-top: none;
}


.visitor-item {
  border-top: 2px solid #e8eaea;
  background-color: #f8f8f8;
}

.visitor-item-active {
  background-color: #fff;
}

.visitor-item-active:hover {
  background-color: #fcfcfc;
}


.live-visitor-tracking-filter-folders {
  background-color: color-mix(in sRGB, var(--bs-base-color) 6%, var(--bs-paper-bg));
}

.truncate-text {
  display: inline-block;
  max-width: 255px; /* adjust as needed */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}

.app-live-visitor-tracking .app-live-visitor-tracking-sidebar .live-visitor-tracking-filters li {
  /* padding-block: 0.75rem !important; */
  padding-block: 1rem !important;
}

/*.live-tracking-visitor-detail {
  color: ;
} */

.live-visitor-tracking-list-item-url a {
  max-width: 850px;
}

.live-visitor-tracking-list .live-tracking-icon {
  block-size: 55px !important;
  inline-size: 55px !important;
}

.live-tracking-visitor-head .bx-user-circle {
  block-size: 40px !important;
  inline-size: 40px !important;
}

@media (width >= 992px) {

  .app-live-visitor-tracking .live-visitor-tracking-list li.live-visitor-tracking-list-item:hover .live-visitor-tracking-list-item-meta .live-visitor-tracking-list-item-time {
    display: contents !important;
  }
}

.all-visitors-session-time {
  width: 106px;
}

/* ==================================================================== */
/* ================= Bucketed sidebar and Active Dock ================= */
/* ==================================================================== */
:root { --sidebar-header-h: 52px; } /* adjust if your header is taller */

.bucket-show-more { padding:10px 14px; display:flex; justify-content:center; }
.bucket-show-more button {
  font-size: 12px; padding: 8px 12px; background: #fff; border:1px solid #e6e8ee; border-radius: 8px;
}
.bucket-show-more button:hover { border-color:#635bff; color:#635bff; }

/* Use same visual language for both docks */
.live-active-dock .dock-btn,
.live-recent-dock .dock-btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 26px;
  background: #f9f9f9;
  color: var(--bs-heading-color);;
  border: 0;
  cursor: pointer;
}

.live-active-dock.is-empty.pulse { animation: none !important; }

/* Stack the two docks neatly (recent sits under active) */
.live-active-dock { position: sticky; top: var(--sidebar-sticky-offset); z-index: 1; }
.live-recent-dock { position: sticky; top: calc(var(--sidebar-sticky-offset) + 42px); z-index: 1; }

/* Hide the mini preview dots entirely */
.live-active-dock .preview { display: none !important; }

/* Active dock dot colors (green; red when empty already supported by .is-empty) */
.live-active-dock .dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: #71dd37;
  box-shadow: 0 0 0 4px rgba(16,185,129,.12);
}
/* When there are zero actives, make the dock dot red */
.live-active-dock.is-empty .dot {
  background: #ff3e1d;
  box-shadow: 0 0 0 4px rgba(239,68,68,.12);
}


/* Recently-left dock dot (orange) */
.live-recent-dock .dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: #f59e0b;
  box-shadow: 0 0 0 4px rgba(245,158,11,.12);
}

/* Count + chevron match */
.live-recent-dock .count,
.live-active-dock .count { margin-left: auto; font-weight: 700; color: #635bff; }
.live-recent-dock .chev,
.live-active-dock .chev { margin-left: 2px; margin-right: 5px; color: #64748b; }

.live-visitor-tracking-filter-folders .visitor-item-active,
.visitor-item,
.live-visitor-tracking-filter-folders .visitor-item-active * {
  cursor: pointer;
}



/* === Live sidebar – mobile off-canvas === */
@media (max-width: 991.98px) {
  #app-live-visitor-tracking-sidebar {
    position: fixed;
    inset: 0 auto 0 0;          /* top:0; left:0; bottom:0 */
    width: 86vw;
    max-width: 420px;
    background: #fff;
    transform: translateX(-100%);
    transition: transform 200ms ease;
    z-index: 1055;              /* above overlay */
    box-shadow: 0 0 30px rgba(2,6,23,.08);
  }
  body.live-sidebar-open #app-live-visitor-tracking-sidebar {
    transform: translateX(0);
  }
  #liveSidebarOverlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, .28);
    opacity: 0;
    visibility: hidden;
    transition: opacity 200ms ease;
    z-index: 1050;
  }
  #liveSidebarOverlay.show { opacity: 1; visibility: visible; }
}

/* Dock + bucket sticky top (so it doesn't hide under navbars) */
:root { --sidebar-sticky-offset: 64px; } /* adjust if your top bar is taller */
.live-active-dock { position: sticky; top: var(--sidebar-sticky-offset); z-index: 1; }
.visitor-bucket-header { position: sticky; top: calc(var(--sidebar-sticky-offset) + 42px); z-index: 1; }

/* Optional: de-emphasize inner bucket header label a bit */
.visitor-bucket-header { font-weight: 500; }

/* Bucket header (neutral) */
.visitor-bucket-header{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 14px;
  position: sticky; top: 51px;
  border-top:1px solid #e6e8ee; border-bottom:1px solid #e6e8ee;
  background:#f7f8fb;
  z-index:1;
}
.visitor-bucket-header .chev{ width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;color:#64748b; }
.visitor-bucket-header .badge{ background:#eef2f7; color:#475569; padding:4px 8px; border-radius:999px; font-size:12px; font-weight:700; }
.visitor-bucket-header .left { display:inline-flex; align-items:center; gap:10px; }
.visitor-bucket-header .meta { margin-left:auto; display:inline-flex; align-items:center; gap:10px; }

.visitor-bucket-header.is-recent .dot{
  background:#ffab00; box-shadow:0 0 0 4px rgba(245,158,11,.12);
}

/* header dot */
.visitor-bucket-header .dot{
  width:10px; height:10px; border-radius:50%;
  display:inline-block;
}

/* variants – neutral greys */
.visitor-bucket-header.is-active{
  background:#f5f5f5;                 /* light grey-tint */
  border-left:4px solid #d5dbe6;      /* subtle rail */
  box-shadow: inset 0 -1px rgba(0,0,0,.035);
}
.visitor-bucket-header.is-recent{
  background:#f3f3f3;                 /* slightly warmer grey */
  border-left:4px solid #e2e2e7;
  box-shadow: inset 0 -1px rgba(0,0,0,.035);
}



/* dock ships */
.dock-chips{ display:flex; gap:.5rem; padding:.5rem .25rem; }
.chip{ display:inline-flex; align-items:center; gap:.4rem; padding:.35rem .6rem;
       border:1px solid #e6e8ee; border-radius:999px; font-size:13px; background:#fff; }
.chip .dot{ width:10px; height:10px; border-radius:50%; display:inline-block; }
.chip--active .dot{ background:#10b981; box-shadow:0 0 0 4px rgba(16,185,129,.12); }
.chip--recent .dot{ background:#f59e0b; box-shadow:0 0 0 4px rgba(245,158,11,.12); }
.chip--daily .dot { background:#635bff; box-shadow:0 0 0 4px rgba(99,91,255,.12); }

/* Tiny tweak so the placeholder <b> aligns nicely inside chips */
.filters-skeleton .chip b.placeholder { display:inline-block; height:1em; vertical-align:middle; }








/*
* Tracking Installation Page
******************************************************************************/

#trackingScript code {
  white-space: pre;
  display: block;
  text-align: left;
}

/*
* Guides and Support
******************************************************************************/

.search-card {
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
}

.search-card-wrapper {
  padding: 35px;
  background-color: rgba(245, 245, 249, 0.51);
  border-radius: 50px 50px 50px 50px;
}

.search-card-inner-wrapper {
  padding: 35px;
  box-shadow: 0 15px 35px 0 rgba(60, 66, 87, 0.08), 0 5px 15px 0 rgba(60, 66, 87, 0.12) !important;
  border-radius: 30px 30px 30px 30px;
}

.faq-header .input-wrapper {
  max-inline-size: 100% !important; /* Or 100% */
}

/*
* Register, Login, Reset, Reset password Account
******************************************************************************/

.authentication-wrapper.authentication-basic {
  overflow: visible !important;
}

.register-account-authentication-wrapper {
  --bs-auth-basic-inner-max-width: auto !important;
}

.account-login-authentication-wrapper, .add-website-authentication-wrapper, .account-login-reset-authentication-wrapper, .account-login-password-reset-authentication-wrapper, .account-login-2fa-authentication-wrapper {
  --bs-auth-basic-inner-max-width: 650px !important;
}

.register-account-wrapper, .account-login-wrapper, .account-login-reset-wrapper, .account-login-password-reset-wrapper, .account-login-2fa-wrapper  {
  padding: 35px;
  border-radius: 50px 50px 50px 50px;
  /* box-shadow: rgba(0, 0, 0, 0.15) 0px 5px 15px 0px; */
}

.account-login-wrapper, .account-login-reset-wrapper, .account-login-password-reset-wrapper, .account-login-2fa-wrapper {
  padding: 45px;
  background-color: rgba(245, 245, 249, 0.51);
}

.register-account-right, .account-login, .account-login-reset, .account-login-password-reset, .account-login-2fa {
  box-shadow: 0 15px 35px 0 rgba(60, 66, 87, 0.08), 0 5px 15px 0 rgba(60, 66, 87, 0.12) !important;
  border-radius: 30px 30px 30px 30px;
}

.authentication-wrapper.authentication-basic .authentication-inner::before, .authentication-wrapper.authentication-basic .authentication-inner::after {
  display: none !important;
  content: none !important;
}

/*
* Register, Login, Reset, Reset password Account Responsive
******************************************************************************/

@media (max-width: 575.98px) { 

/*  .logo-title img {
    width: 150px !important;
  } */

  .hero-text-box h2, .landing-features h2, .integrations-text-wrapper h2, .landing-pricing h2 {
    line-height: 2.2rem !important;
  }

  .account-login-wrapper, .account-login-reset-wrapper, .account-login-password-reset-wrapper, .account-login-2fa-wrapper {
    padding: 20px;
  }

  .register-account-wrapper {
    padding: 20px;
  }

}

/*
* Add Website
******************************************************************************/

.add-website-wrapper {
  padding: 45px;
  border-radius: 50px 50px 50px 50px;
  background-color: rgba(245, 245, 249, 0.51);
}

.add-website {
  box-shadow: 0 15px 35px 0 rgba(60, 66, 87, 0.08), 0 5px 15px 0 rgba(60, 66, 87, 0.12) !important;
  border-radius: 30px 30px 30px 30px;
}

.select2-container--default .select2-selection--single {
  height: 41px !important;
  padding: 6px 12px;
  border: 1px solid #ced4da; /* matches Bootstrap form-control border */
  border-radius: 0.375rem; /* matches Bootstrap rounded */
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 27px; /* to center the text vertically */
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 41px !important;
  top: 0px !important;
}

/*
* User Profile CSS
******************************************************************************/

.user-avatar-section .avatar {
  --bs-avatar-size: 3.375rem !important;
}

/*
* Root CSS
******************************************************************************/

:root,
[data-bs-theme=light] {
--bs-primary: #635bff; /* Blue - #015bf8 */
}

.noUi-target {
--bs-noUi-base-color: #015bf8 !important;
}

.text-primary {
  color: #635bff !important;
}

/*
* Content
******************************************************************************/

.demo-blocks > * {
  display: block !important;
}

.demo-inline-spacing > * {
  margin: 1rem 0.375rem 0 0 !important;
}

/* ? .demo-vertical-spacing class is used to have vertical margins between elements. To remove margin-top from the first-child, use .demo-only-element class with .demo-vertical-spacing class. For example, we have used this class in forms-input-groups.html file. */
.demo-vertical-spacing > * {
  margin-top: 1rem !important;
  margin-bottom: 0 !important;
}
.demo-vertical-spacing.demo-only-element > :first-child {
  margin-top: 0 !important;
}

.demo-vertical-spacing-lg > * {
  margin-top: 1.875rem !important;
  margin-bottom: 0 !important;
}
.demo-vertical-spacing-lg.demo-only-element > :first-child {
  margin-top: 0 !important;
}

.demo-vertical-spacing-xl > * {
  margin-top: 5rem !important;
  margin-bottom: 0 !important;
}
.demo-vertical-spacing-xl.demo-only-element > :first-child {
  margin-top: 0 !important;
}

/* Dropdown buttons going out of small screens */
@media (max-width: 576px) {
  #dropdown-variation-demo .btn-group .text-truncate {
    width: 231px;
    position: relative;
  }
  #dropdown-variation-demo .btn-group .text-truncate::after {
    position: absolute;
    top: 45%;
    right: 0.65rem;
  }
}

/*
* Contact
******************************************************************************/


/*
* AI Assistant
******************************************************************************/

/* Floating AI button */
.ai-assistant-button {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 1001;
  background: #2d2dff;
  color: white;
  padding: 10px 15px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2);
}

/* Slide-in panel */
.ai-assistant-panel {
  position: fixed;
  top: 0;
  right: -400px;
  width: 400px;
  height: 100%;
  background: #fefefe;
  border-left: 1px solid #ccc;
  box-shadow: -2px 0 8px rgba(0,0,0,0.1);
  transition: right 0.3s ease-in-out;
  z-index: 1000;
  display: flex;
  flex-direction: column;
}

.ai-assistant-panel.open {
  right: 0;
}

.ai-header {
  display: flex;
  justify-content: space-between;
  padding: 15px;
  background: #2d2dff;
  color: white;
}

.ai-form {
  padding: 15px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ai-form label {
  font-weight: bold;
}

.ai-form input,
.ai-form select,
.ai-form button {
  padding: 8px;
  font-size: 14px;
}

.ai-output {
  flex-grow: 1;
  padding: 15px;
  overflow-y: auto;
  background: #f9f9f9;
  border-top: 1px solid #eee;
}

.typing-dots {
  font-weight: bold;
  margin-bottom: 10px;
  animation: blink 1.4s infinite;
}

@keyframes blink {
  0%, 100% { opacity: 1 }
  50% { opacity: 0.4 }
}

#aiAssistantToggle {
  border-radius: 50px;
  padding: 10px 20px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

#aiInsightsText {
  /*max-height: 300px;*/
  overflow-y: auto;
}





/*
* Layout demo
******************************************************************************/

.layout-demo-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin-top: 1rem;
}
.layout-demo-placeholder img {
  width: 900px;
}
.layout-demo-info {
  text-align: center;
  margin-top: 1rem;
}