/* General reset */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
 
  background-color: #f3f3f3;
}

/* Top Bar */
.top-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: #2b579a;
  color: white;
  padding: 0 15px;
  height: 50px;
  position:fixed;
  width:100%;
  z-index:8;
}

.logo {
  font-size: 20px;
  font-weight: bold;
}

.tabs {
  display: flex;
  gap: 15px;
  height: 100%;
}

.tab {
  cursor: pointer;
  padding: 5px 10px;
  border-radius: 4px;
  display: flex;
  align-items: center;
}

.tab:hover {
  background-color: #1e4e8c;
}

.actions {
  display: flex;
  align-items: center;
}

.action-btn {
  background-color: white;
  color: #2b579a;
  border: none;
  padding: 5px 15px;
  border-radius: 4px;
  cursor: pointer;
  font-weight: bold;
}

.action-btn:hover {
  background-color: #dce6f2;
}

/* Ribbon */
.ribbon {
  display: flex;
  flex-direction: column;
  padding: 5px;
  background-color: white;
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  position: fixed;
  width:100%;
  z-index:1001;
  top: 50px;
}

.ribbon-content {
  display: none;
  flex-wrap: nowrap;
  gap: 20px;
  margin-left: 10px;
  overflow-x: auto; 
  overflow-y: hidden;

  scrollbar-width: thin; 
}

.ribbon-content::-webkit-scrollbar {
  height: 2px;                 /* thin */
}

.ribbon-content::-webkit-scrollbar-track {
  background: transparent;
}

.ribbon-content::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,0.1);
  border-radius: 10px;
}

.ribbon-content::-webkit-scrollbar-thumb:hover {
  background: rgba(0,0,0,0.35);
}

.ribbon-group {
  flex: 0 0 auto;   /* 🔥 critical */
}

.ribbon-content.active {
  display: flex;
}

.ribbon-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 5px 20px 0px 0px;
  border-right: 1px solid #ddd;
  margin: 0px 0px;
}

.ribbon-group:last-child {
  border-right: none;
}

.ribbon-items {
  display: flex;
  gap: 10px;
  justify-content: center;
}

.ribbon-button {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #f3f3f3;
  border: 1px solid #ccc;
  padding: 5px;
  width: 60px;
  height: 60px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 11px;
  text-align: center;
  position: relative;
}

.ribbon-button .icon {
  font-size: 20px;
  font-family: "Noto Sans Symbols 2", sans-serif;
}

.ribbon-button:hover {
  background-color: #eaeaea;
}

.dropdown-indicator {
  position: absolute;
  bottom: 5px;
  right: 5px;
  font-size: 12px;
  color: #555;
}

.missing-indicator {
  position: absolute;
  top: 5px;
  right: 5px;
  font-size: 12px;
  color: #555;
}

.group-description {
  text-align: center;
  font-size: 10px;
  color: #555;
  margin-top: 5px;
}

/* Dropdown */
.dropdown-content {
  display: none;
  position: absolute;
  background-color: white;
  border: 1px solid #ddd;
  box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  flex-direction: column;
  width: 150px;
}

.dropdown-item {
  padding: 10px;
  text-align: left;
  border: none;
  background: none;
  cursor: pointer;
  width: 100%;
  font-size: 14px;
}

.dropdown-item:hover {
  background-color: #f3f3f3;
}



.tabs .tab.active {
  background-color: #1e4e8c;
  text-decoration: underline;
}

.icon-btn {
    background: none;
    border: none;
    color: white;
    font-size: 20px;
    cursor: pointer;
    transition: opacity 0.3s ease;
  }

  .icon-btn:hover {
    opacity: 0.7;
  }
  
   .icon-btn.firstbtn {
    margin-left: -20%;
  }

  .icon-btn.lastbtn {
    margin-right: 10%;
  }

/* Desktop guard: mobile file controls must not appear or affect desktop */
.mobile-file-toggle,
.mobile-file-menu {
  display: none;
}

/* Desktop guard: keep run controls in normal desktop flow */
.run-controls {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* =========================================================
   Mobile layout - published version
   Single final definition block. Keep this as the only mobile
   ribbon/top-bar/dropdown layer block to avoid override fights.
   ========================================================= */

body > .mobile-file-menu {
  display: none;
}

@media (max-width: 760px) {
  :root {
    --mobile-blue: #2b579a;
    --mobile-blue-dark: #1e4e8c;
    --mobile-topbar-height: 86px;
    --mobile-ribbon-top: 86px;
    --mobile-ribbon-height: 113px;
    --mobile-runbar-height: 44px;
    --mobile-runbar-top: calc(var(--mobile-ribbon-top) + var(--mobile-ribbon-height) - 10px);
  }

  .top-bar {
    height: var(--mobile-topbar-height) !important;
    padding: 0 8px !important;
    display: grid !important;
    grid-template-columns: auto 1fr auto !important;
    grid-template-rows: 44px 42px !important;
    align-items: center !important;
    background-color: var(--mobile-blue) !important;
    color: #fff !important;
    overflow: visible !important;
    z-index: auto !important;
  }

  .logo-wrap {
    grid-column: 1 !important;
    grid-row: 1 !important;
    justify-self: start !important;
    align-self: center !important;
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    min-width: 0 !important;
    max-width: calc(100vw - 108px) !important;
    overflow: visible !important;
    position: relative !important;
    z-index: auto !important;
  }

  .logo {
    font-size: 19px !important;
    line-height: 1 !important;
    color: #fff !important;
    white-space: nowrap !important;
  }

  .actions {
    grid-column: 3 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    align-self: center !important;
    display: flex !important;
    align-items: center !important;
    z-index: 2147483000 !important;
  }

  /* Tabs scroll horizontally on mobile, but keep the scrollbar hidden. */
  .tabs {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    height: 42px !important;
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    white-space: nowrap !important;
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior-x: contain !important;
    padding: 0 4px !important;
  }

  .tabs::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
  }

  .tab {
    flex: 0 0 auto !important;
    height: 32px !important;
    padding: 0 10px !important;
    color: #fff !important;
  }

  .tabs .tab.active,
  .tab:hover {
    background-color: var(--mobile-blue-dark) !important;
  }

  .file-action-btn {
    display: none !important;
  }

  .run-controls {
    position: fixed !important;
    top: var(--mobile-runbar-top) !important;
    left: 0 !important;
    right: 0 !important;
    height: var(--mobile-runbar-height) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 5px 8px !important;
    background: var(--mobile-blue) !important;
    border: none !important;
    box-shadow: none !important;
    z-index: 7000 !important;
  }

  .run-controls .icon-btn,
  .run-controls #runBtn,
  .run-controls #pauseBtn,
  .run-controls #stopBtn,
  .run-controls #runBtnApp {
    width: auto !important;
    min-width: 42px !important;
    height: 32px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 0 6px !important;
    border: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: #fff !important;
    font-size: 17px !important;
    line-height: 1 !important;
  }

  .run-controls .icon-btn:disabled {
    opacity: .48 !important;
    cursor: not-allowed !important;
  }

  #pauseBtn,
  #stopBtn {
    margin-top: 0 !important;
    font-size: 17px !important;
  }

  .ribbon {
    position: fixed !important;
    top: var(--mobile-ribbon-top) !important;
    width: 100% !important;
    height: auto !important;
    padding: 10px 0 0 !important;
    background-color: #fff !important;
    border-top: 0 !important;
    border-bottom: 1px solid #ddd !important;
    overflow: visible !important;
    z-index: 10000 !important;
  }

  /* Ribbon is the only mobile area with horizontal scrolling. */
  .ribbon-content,
  .ribbon-content.active {
    height: calc(var(--mobile-ribbon-height) - 20px) !important;
    margin-left: 0 !important;
    padding: 0 8px 10px !important;
    display: none !important;
    flex-wrap: nowrap !important;
    gap: 10px !important;
    align-items: stretch !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: thin !important;
  }

  .ribbon-content.active {
    display: flex !important;
  }

  .ribbon-content::-webkit-scrollbar,
  .ribbon-content.active::-webkit-scrollbar {
    height: 3px !important;
    width: 0 !important;
  }

  .ribbon-content::-webkit-scrollbar-track,
  .ribbon-content.active::-webkit-scrollbar-track {
    background: transparent !important;
  }

  .ribbon-content::-webkit-scrollbar-thumb,
  .ribbon-content.active::-webkit-scrollbar-thumb {
    background: rgba(0,0,0,.18) !important;
    border-radius: 999px !important;
  }

  .ribbon-group {
    flex: 0 0 auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    min-height: 102px !important;
    padding: 4px 12px 8px 0 !important;
    border-right: 1px solid #ddd !important;
    overflow: visible !important;
  }

  .ribbon-items {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
    gap: 10px !important;
    min-height: 62px !important;
    overflow: visible !important;
  }

  .ribbon .dropdown,
  .ribbon-button {
    overflow: visible !important;
  }

  .ribbon-button {
    width: 58px !important;
    height: 58px !important;
    padding: 4px 3px !important;
    font-size: 10px !important;
    line-height: 1.1 !important;
  }

  .ribbon-button .icon {
    font-size: 18px !important;
  
  }

  .ribbon-button .label {
    display: block !important;
    max-width: 100% !important;
    line-height: 1.05 !important;
    white-space: normal !important;
    overflow: visible !important;
  }

  .group-description {
    display: block !important;
    margin-top: 6px !important;
    padding-bottom: 2px !important;
    line-height: 1.15 !important;
    white-space: nowrap !important;
    overflow: visible !important;
  }

  /* Normal ribbon dropdowns are viewport-layered.
     The mobile JS in ribbon.php sets the two CSS variables below. */
  .ribbon .dropdown-content,
  .ribbon .dropdown-content.show,
  .dropdown-content.mobile-ribbon-dropdown-open {
    position: fixed !important;
    top: var(--mobile-dropdown-top, 0px) !important;
    left: var(--mobile-dropdown-left, 0px) !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    z-index: 2147482000 !important;
    min-width: 150px !important;
    max-width: calc(100vw - 16px) !important;
    max-height: calc(100vh - var(--mobile-dropdown-top, 0px) - 8px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  .ribbon .dropdown-item,
  .dropdown-content.mobile-ribbon-dropdown-open .dropdown-item {
    position: relative !important;
    z-index: 2147482001 !important;
  }

  .mobile-file-toggle {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 26px !important;
    height: 30px !important;
    min-width: 26px !important;
    min-height: 30px !important;
    padding: 0 !important;
    margin: 0 2px 0 4px !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    color: transparent !important;
    font-size: 0 !important;
    line-height: 0 !important;
    text-indent: -9999px !important;
    cursor: pointer !important;
    overflow: visible !important;
    z-index: 2147483302 !important;
  }

  .mobile-file-toggle > * {
    display: none !important;
  }

  .mobile-file-toggle::before,
  body.mobile-files-open .mobile-file-toggle::before {
    content: "" !important;
    position: absolute !important;
    display: block !important;
    left: 7px !important;
    top: 8px !important;
    width: 11px !important;
    height: 1px !important;
    background: rgba(255,255,255,.96) !important;
    box-shadow: 0 4px 0 rgba(255,255,255,.96) !important;
    border: none !important;
    transform: none !important;
    text-indent: 0 !important;
  }

  .mobile-file-toggle::after,
  body.mobile-files-open .mobile-file-toggle::after {
    content: "" !important;
    position: absolute !important;
    display: block !important;
    left: 9px !important;
    top: 17px !important;
    width: 0 !important;
    height: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border-left: 4px solid transparent !important;
    border-right: 4px solid transparent !important;
    border-top: 5px solid rgba(255,255,255,.96) !important;
    border-bottom: 0 !important;
    transform: none !important;
    text-indent: 0 !important;
  }

  .mobile-file-toggle:hover,
  .mobile-file-toggle:focus,
  .mobile-file-toggle:active,
  body.mobile-files-open .mobile-file-toggle {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    opacity: .86 !important;
  }

  /* The PHP helper moves this menu to body on mobile. */
  body > .mobile-file-menu,
  body.mobile-files-open > .mobile-file-menu {
    position: fixed !important;
    top: 42px !important;
    left: 8px !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    z-index: 2147483300 !important;

    display: none !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;

    min-width: 172px !important;
    width: max-content !important;
    max-width: calc(100vw - 16px) !important;
    max-height: calc(100vh - 56px) !important;

    overflow-y: auto !important;
    overflow-x: hidden !important;

    background: #ffffff !important;
    color: #172033 !important;
    border: 1px solid #d8dee8 !important;
    border-radius: 10px !important;
    box-shadow: 0 18px 45px rgba(15,23,42,.22) !important;
    padding: 6px !important;
    margin: 0 !important;
  }

  body.mobile-files-open > .mobile-file-menu {
    display: flex !important;
  }

  body > .mobile-file-menu .mobile-file-action {
    position: relative !important;
    z-index: 2147483301 !important;
    width: 100% !important;
    height: 36px !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;

    margin: 0 !important;
    padding: 0 10px !important;
    background: transparent !important;
    border: none !important;
    border-radius: 7px !important;
    box-shadow: none !important;

    color: #172033 !important;
    font-size: 18px !important;
    line-height: 1 !important;
    text-align: left !important;
    white-space: nowrap !important;
  }

  body > .mobile-file-menu .mobile-file-action:hover,
  body > .mobile-file-menu .mobile-file-action:focus,
  body > .mobile-file-menu .mobile-file-action:active {
    background: #f1f5f9 !important;
    border: none !important;
    box-shadow: none !important;
    opacity: 1 !important;
  }

  body > .mobile-file-menu .mobile-file-action::after {
    display: inline-block !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    color: #172033 !important;
  }

  body > .mobile-file-menu .mobile-file-action:nth-child(1)::after { content: "New File" !important; }
  body > .mobile-file-menu .mobile-file-action:nth-child(2)::after { content: "Save" !important; }
  body > .mobile-file-menu .mobile-file-action:nth-child(3)::after { content: "Save as" !important; }
  body > .mobile-file-menu .mobile-file-action:nth-child(4)::after { content: "Open" !important; }

  #popdownModalfull.modal,
  #popdownModalfull.modal.show,
  .modal#popdownModalfull,
  .modal#popdownModalfull.show,
  #authPanel.auth-required-modal,
  #filenameModalOverlay {
    z-index: 2147483600 !important;
  }
}


/* =========================================================
   Desktop/tablet action button spacing
   ========================================================= */
@media (min-width: 761px) {
  .icon-btn.firstbtn {
    margin-left: -10% !important;
  }
}

@media (min-width: 761px) and (max-width: 1149px) {
  .icon-btn.firstbtn {
    margin-left: -3% !important;
  }
}

/* Hide the four file action buttons below 1050px, like mobile */
@media (max-width: 1049px) {
  .file-action-btn {
    display: none !important;
  }
}


/* =========================================================
   Compact file actions for desktop/tablet below 1050px
   - hide the four normal file buttons
   - show the same small toggle/menu used on mobile
   ========================================================= */
@media (min-width: 761px) and (max-width: 1049px) {
  .file-action-btn {
    display: none !important;
  }

  .logo-wrap {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    position: relative !important;
    overflow: visible !important;
    z-index: 10000 !important;
  }

  .mobile-file-toggle {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 26px !important;
    height: 30px !important;
    min-width: 26px !important;
    min-height: 30px !important;
    padding: 0 !important;
    margin: 0 2px 0 4px !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    color: transparent !important;
    font-size: 0 !important;
    line-height: 0 !important;
    text-indent: -9999px !important;
    cursor: pointer !important;
    overflow: visible !important;
    z-index: 10002 !important;
  }

  .mobile-file-toggle > * {
    display: none !important;
  }

  .mobile-file-toggle::before,
  body.mobile-files-open .mobile-file-toggle::before {
    content: "" !important;
    position: absolute !important;
    display: block !important;
    left: 7px !important;
    top: 8px !important;
    width: 11px !important;
    height: 1px !important;
    background: rgba(255,255,255,.96) !important;
    box-shadow: 0 4px 0 rgba(255,255,255,.96) !important;
    border: none !important;
    transform: none !important;
    text-indent: 0 !important;
  }

  .mobile-file-toggle::after,
  body.mobile-files-open .mobile-file-toggle::after {
    content: "" !important;
    position: absolute !important;
    display: block !important;
    left: 9px !important;
    top: 17px !important;
    width: 0 !important;
    height: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border-left: 4px solid transparent !important;
    border-right: 4px solid transparent !important;
    border-top: 5px solid rgba(255,255,255,.96) !important;
    border-bottom: 0 !important;
    transform: none !important;
    text-indent: 0 !important;
  }

  .mobile-file-toggle:hover,
  .mobile-file-toggle:focus,
  .mobile-file-toggle:active,
  body.mobile-files-open .mobile-file-toggle {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    opacity: .86 !important;
  }

  .mobile-file-menu,
  body.mobile-files-open .mobile-file-menu {
    position: absolute !important;
    top: 34px !important;
    left: 0 !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;

    display: none !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;

    min-width: 172px !important;
    width: max-content !important;
    max-width: calc(100vw - 16px) !important;
    max-height: calc(100vh - 56px) !important;

    overflow-y: auto !important;
    overflow-x: hidden !important;

    background: #ffffff !important;
    color: #172033 !important;
    border: 1px solid #d8dee8 !important;
    border-radius: 10px !important;
    box-shadow: 0 18px 45px rgba(15,23,42,.22) !important;
    padding: 6px !important;
    margin: 0 !important;
    z-index: 10003 !important;
  }

  body.mobile-files-open .mobile-file-menu {
    display: flex !important;
  }

  .mobile-file-action {
    width: 100% !important;
    height: 36px !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    margin: 0 !important;
    padding: 0 10px !important;
    background: transparent !important;
    border: none !important;
    border-radius: 7px !important;
    box-shadow: none !important;
    color: #172033 !important;
    font-size: 18px !important;
    line-height: 1 !important;
    text-align: left !important;
    white-space: nowrap !important;
  }

  .mobile-file-action:hover,
  .mobile-file-action:focus,
  .mobile-file-action:active {
    background: #f1f5f9 !important;
    border: none !important;
    box-shadow: none !important;
    opacity: 1 !important;
  }

  .mobile-file-action::after {
    display: inline-block !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    color: #172033 !important;
  }

  .mobile-file-action:nth-child(1)::after { content: "New File" !important; }
  .mobile-file-action:nth-child(2)::after { content: "Save" !important; }
  .mobile-file-action:nth-child(3)::after { content: "Save as" !important; }
  .mobile-file-action:nth-child(4)::after { content: "Open" !important; }
}


/* =========================================================
   Compact file menu layer fix: 761px-1049px
   Keep compact file options above ribbon/dropdowns.
   ========================================================= */
@media (min-width: 761px) and (max-width: 1049px) {
  .top-bar {
    z-index: 30000 !important;
    overflow: visible !important;
  }

  .logo-wrap {
    position: relative !important;
    z-index: 30010 !important;
    overflow: visible !important;
  }

  .mobile-file-toggle {
    position: relative !important;
    z-index: 30020 !important;
  }

  .mobile-file-menu,
  body.mobile-files-open .mobile-file-menu {
    position: absolute !important;
    top: 34px !important;
    left: 0 !important;
    z-index: 30030 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  body.mobile-files-open .mobile-file-menu {
    display: flex !important;
  }

  .ribbon {
    z-index: 1001 !important;
  }

  .run-controls {
    position: relative !important;
    z-index: auto !important;
  }
}


/* =========================================================
   Aiigle info burger menu beside sign-in/logout
   ========================================================= */
.aiigle-info-menu-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  margin-left: 10px;
  z-index: 32000;
}

.aiigle-info-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: 7px;
  background: transparent;
  color: #ffffff;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

.aiigle-info-toggle:hover,
.aiigle-info-toggle:focus,
body.aiigle-info-open .aiigle-info-toggle {
  background: rgba(255,255,255,.14);
  outline: none;
}

.aiigle-info-menu {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: min(320px, calc(100vw - 24px));
  max-width: 320px;
  padding: 10px;
  background: #ffffff;
  color: #172033;
  border: 1px solid #d8dee8;
  border-radius: 12px;
  box-shadow: 0 18px 45px rgba(15,23,42,.22);
  z-index: 32010;
}

body.aiigle-info-open .aiigle-info-menu {
  display: block;
}

.aiigle-info-item {
  display: block;
  width: 100%;
  padding: 11px 12px;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: #172033;
  text-align: left;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
}

.aiigle-info-item:hover,
.aiigle-info-item:focus {
  background: #f1f5f9;
  outline: none;
}

.aiigle-info-legal {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
  padding: 8px 10px 2px;
  border-top: 1px solid #e5eaf2;
  color: #64748b;
  font-size: 11px;
  line-height: 1.2;
}

.aiigle-info-legal a {
  padding: 0;
  border: none;
  background: transparent;
  color: #64748b;
  font-size: 11px;
  line-height: 1.2;
  cursor: pointer;
}

.aiigle-info-legal a:hover,
.aiigle-info-legal a:focus {
  color: #172033;
  text-decoration: underline;
  outline: none;
}

@media (max-width: 760px) {
  .aiigle-info-menu-wrap {
    grid-column: 3 !important;
    grid-row: 1 !important;
    margin-left: 6px !important;
    z-index: 2147483400 !important;
  }

  .aiigle-info-toggle {
    width: 32px !important;
    height: 32px !important;
    font-size: 23px !important;
  }

  .aiigle-info-menu {
    position: fixed !important;
    top: var(--mobile-topbar-height, 86px) !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: none !important;
    border-left: none !important;
    border-right: none !important;
    border-radius: 0 0 14px 14px !important;
    padding: 12px !important;
    z-index: 2147483401 !important;
  }

  .aiigle-info-item {
    padding: 13px 12px !important;
    font-size: 16px !important;
  }

  .aiigle-info-legal {
    justify-content: center !important;
    font-size: 11px !important;
  }
}


/* =========================================================
   Aiigle info menu layer fix
   - keep menu above tabs, ribbon, ribbon dropdowns and compact file menu
   - keep real modals above it
   ========================================================= */
.aiigle-info-menu-wrap {
  z-index: 2147483450 !important;
}

.aiigle-info-toggle {
  position: relative !important;
  z-index: 2147483451 !important;
}

.aiigle-info-menu,
body.aiigle-info-open .aiigle-info-menu {
  z-index: 2147483452 !important;
}

@media (min-width: 761px) {
  .top-bar {
    z-index: 2147483400 !important;
    overflow: visible !important;
  }

  .aiigle-info-menu-wrap {
    position: relative !important;
    z-index: 2147483450 !important;
  }

  .aiigle-info-menu {
    position: absolute !important;
    z-index: 2147483452 !important;
  }
}

@media (max-width: 760px) {
  .top-bar {
    z-index: 2147483400 !important;
    overflow: visible !important;
  }

  .aiigle-info-menu-wrap {
    z-index: 2147483450 !important;
  }

  .aiigle-info-menu,
  body.aiigle-info-open .aiigle-info-menu {
    position: fixed !important;
    top: var(--mobile-topbar-height, 86px) !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 2147483452 !important;
  }

  #popdownModalfull.modal,
  #popdownModalfull.modal.show,
  .modal#popdownModalfull,
  .modal#popdownModalfull.show,
  #authPanel.auth-required-modal,
  #filenameModalOverlay {
    z-index: 2147483600 !important;
  }
}


/* =========================================================
   Aiigle info menu visual style - simple vertical menu
   ========================================================= */
.aiigle-info-menu {
  background: #2b579a !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: 0 14px 34px rgba(15,23,42,.26) !important;
  padding: 6px 0 !important;
  backdrop-filter: none !important;
}

.aiigle-info-item {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 12px 18px !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  text-align: left !important;
}

.aiigle-info-item:hover,
.aiigle-info-item:focus {
  background: #1e4e8c !important;
  color: #ffffff !important;
  border: none !important;
  outline: none !important;
}

.aiigle-info-legal {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin: 6px 0 0 !important;
  padding: 10px 18px 6px !important;
  border-top: 1px solid rgba(255,255,255,.22) !important;
  color: rgba(255,255,255,.78) !important;
  font-size: 11px !important;
  line-height: 1.2 !important;
}

.aiigle-info-legal a,
.aiigle-info-legal span {
  color: rgba(255,255,255,.78) !important;
  font-size: 11px !important;
  font-weight: 400 !important;
}

.aiigle-info-legal a {
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  cursor: pointer !important;
}

.aiigle-info-legal a:hover,
.aiigle-info-legal a:focus {
  color: #ffffff !important;
  text-decoration: underline !important;
  outline: none !important;
}

.aiigle-info-legal {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 6px !important;
  width: 100% !important;
  text-align: center !important;
}

.aiigle-info-legal a,
.aiigle-info-legal span {
  display: inline-flex !important;
  align-items: center !important;
}

@media (max-width: 760px) {
  .aiigle-info-menu {
    border-radius: 0 !important;
    padding: 6px 0 !important;
    box-shadow: 0 12px 28px rgba(15,23,42,.28) !important;
  }

  .aiigle-info-item {
    padding: 14px 18px !important;
    font-size: 16px !important;
    font-weight: 400 !important;
  }

  .aiigle-info-legal {
    justify-content: center !important;
    padding: 11px 14px 7px !important;
  }
}


/* =========================================================
   Aiigle info menu behavior refinements
   - mobile menu overlays tabs
   - burger becomes X when open
   - desktop menu sticks to right page edge
   ========================================================= */
.aiigle-info-toggle {
  font-size: 0 !important;
  position: relative !important;
}

.aiigle-info-toggle::before {
  content: "☰" !important;
  display: block !important;
  color: #ffffff !important;
  font-size: 24px !important;
  line-height: 1 !important;
  font-weight: 400 !important;
}

body.aiigle-info-open .aiigle-info-toggle::before {
  content: "×" !important;
  font-size: 32px !important;
  line-height: .85 !important;
  font-weight: 300 !important;
}

@media (min-width: 761px) {
  .aiigle-info-menu {
    position: fixed !important;
    top: 50px !important;
    right: 0 !important;
    left: auto !important;
    margin: 0 !important;
    width: 320px !important;
    max-width: 320px !important;
  }
}

@media (max-width: 760px) {
  .aiigle-info-menu,
  body.aiigle-info-open .aiigle-info-menu {
    position: fixed !important;

    /* overlay the tabs row instead of starting below it */
    top: 44px !important;
    left: 0 !important;
    right: 0 !important;

    width: 100vw !important;
    max-width: none !important;
    margin: 0 !important;

    z-index: 2147483452 !important;
  }

  .tabs {
    z-index: 1 !important;
  }

  .aiigle-info-toggle::before {
    font-size: 24px !important;
  }

  body.aiigle-info-open .aiigle-info-toggle::before {
    font-size: 32px !important;
  }
}


/* =========================================================
   Aiigle info toggle hover: no background, only icon opacity
   ========================================================= */
.aiigle-info-toggle,
.aiigle-info-toggle:hover,
.aiigle-info-toggle:focus,
.aiigle-info-toggle:active,
body.aiigle-info-open .aiigle-info-toggle,
body.aiigle-info-open .aiigle-info-toggle:hover,
body.aiigle-info-open .aiigle-info-toggle:focus,
body.aiigle-info-open .aiigle-info-toggle:active {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}

.aiigle-info-toggle::before {
  opacity: 1 !important;
  transition: opacity .16s ease !important;
}

.aiigle-info-toggle:hover::before,
.aiigle-info-toggle:focus::before,
body.aiigle-info-open .aiigle-info-toggle:hover::before,
body.aiigle-info-open .aiigle-info-toggle:focus::before {
  opacity: .72 !important;
}


/* =========================================================
   FINAL layer repair
   Problem:
   .top-bar was raised for the Aiigle info menu. Because run-controls
   lives inside .top-bar, this can put run-controls above ribbon dropdowns.
   Fix:
   - do not use .top-bar as the high layer globally
   - put only the menus themselves on high fixed/absolute layers
   ========================================================= */

/* Desktop/tablet: keep top bar normal, only compact file menu/info menu high */
@media (min-width: 761px) {
  .top-bar {
    z-index: 3000 !important;
    overflow: visible !important;
  }

  .ribbon {
    z-index: 1001 !important;
  }

  .run-controls {
    position: static !important;
    z-index: auto !important;
  }

  .aiigle-info-menu,
  body.aiigle-info-open .aiigle-info-menu {
    position: fixed !important;
    top: 50px !important;
    right: 0 !important;
    left: auto !important;
    z-index: 2147483452 !important;
  }
}

/* Compact desktop/tablet file menu: must be above ribbon */
@media (min-width: 761px) and (max-width: 1049px) {
  .logo-wrap {
    position: relative !important;
    z-index: 2147483300 !important;
    overflow: visible !important;
  }

  .mobile-file-toggle {
    position: relative !important;
    z-index: 2147483301 !important;
  }

  .mobile-file-menu,
  body.mobile-files-open .mobile-file-menu {
    position: absolute !important;
    top: 34px !important;
    left: 0 !important;
    right: auto !important;
    display: none !important;
    z-index: 2147483302 !important;
  }

  body.mobile-files-open .mobile-file-menu {
    display: flex !important;
  }
}

/* Mobile: ribbon dropdowns above run-controls; file menu and info menu above ribbon dropdowns */
@media (max-width: 760px) {
  .top-bar {
    z-index: auto !important;
    overflow: visible !important;
  }

  .run-controls {
    position: fixed !important;
    z-index: 7000 !important;
    top: var(--mobile-runbar-top) !important;
    left: 0 !important;
    right: 0 !important;
  }

  .ribbon {
    position: fixed !important;
    z-index: 10000 !important;
    overflow: visible !important;
  }

  .ribbon-content,
  .ribbon-content.active {
    overflow-x: auto !important;
    overflow-y: hidden !important;
  }

  .ribbon .dropdown-content,
  .ribbon .dropdown-content.show,
  .dropdown-content.mobile-ribbon-dropdown-open {
    position: fixed !important;
    top: var(--mobile-dropdown-top, 0px) !important;
    left: var(--mobile-dropdown-left, 0px) !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    z-index: 2147482000 !important;
  }

  body > .mobile-file-menu,
  body.mobile-files-open > .mobile-file-menu {
    position: fixed !important;
    top: 42px !important;
    left: 8px !important;
    z-index: 2147483300 !important;
  }

  body.mobile-files-open > .mobile-file-menu {
    display: flex !important;
  }

  .aiigle-info-menu,
  body.aiigle-info-open .aiigle-info-menu {
    position: fixed !important;
    top: 44px !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: none !important;
    z-index: 2147483452 !important;
  }

  #popdownModalfull.modal,
  #popdownModalfull.modal.show,
  .modal#popdownModalfull,
  .modal#popdownModalfull.show,
  #authPanel.auth-required-modal,
  #filenameModalOverlay {
    z-index: 2147483600 !important;
  }
}



/* =========================================================
   Mobile Aiigle info menu body-layer fix
   The menu is moved to <body> on mobile so it is not trapped
   inside the top-bar stacking context and can overlay the ribbon.
   ========================================================= */
@media (max-width: 760px) {
  body > .aiigle-info-menu,
  body.aiigle-info-open > .aiigle-info-menu {
    position: fixed !important;
    top: 44px !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: none !important;
    margin: 0 !important;
    z-index: 2147483452 !important;
  }
}


/* Mobile: put open ribbon dropdowns on the body layer so they stay above run-controls on iPhone. */
@media (max-width: 760px) {
  body > .dropdown-content.mobile-ribbon-dropdown-open {
    position: fixed !important;
    top: var(--mobile-dropdown-top, 0px) !important;
    left: var(--mobile-dropdown-left, 0px) !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    display: block !important;
    z-index: 2147483400 !important;
    min-width: 150px !important;
    max-width: calc(100vw - 16px) !important;
    max-height: calc(100vh - var(--mobile-dropdown-top, 0px) - 8px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
  }

  body > .dropdown-content.mobile-ribbon-dropdown-open .dropdown-item {
    position: relative !important;
    z-index: 2147483401 !important;
  }
}

/* Premium file toolbar SVG icons (local assets from /lib/svg/) */
.file-action-btn,
.mobile-file-action {
  color: #fff !important;
}

.file-svg-icon {
  display: inline-block !important;
  width: 22px !important;
  height: 22px !important;
  flex: 0 0 22px !important;
  background-color: currentColor !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;
  -webkit-mask-repeat: no-repeat !important;
  mask-repeat: no-repeat !important;
  -webkit-mask-position: center !important;
  mask-position: center !important;
  -webkit-mask-size: contain !important;
  mask-size: contain !important;
  vertical-align: middle !important;
}

.file-svg-new {
  -webkit-mask-image: url("../lib/svg/new.svg") !important;
  mask-image: url("../lib/svg/new.svg") !important;
}

.file-svg-save {
  -webkit-mask-image: url("../lib/svg/save.svg") !important;
  mask-image: url("../lib/svg/save.svg") !important;
}

.file-svg-saveas {
  -webkit-mask-image: url("../lib/svg/saveas.svg") !important;
  mask-image: url("../lib/svg/saveas.svg") !important;
}

.file-svg-open {
  -webkit-mask-image: url("../lib/svg/folder-open.svg") !important;
  mask-image: url("../lib/svg/folder-open.svg") !important;
}

.file-action-btn .file-svg-icon,
.mobile-file-action .file-svg-icon {
  pointer-events: none !important;
}

/* Premium run-control SVG icons (local assets from /lib/svg/) */
.run-action-btn {
  color: #fff !important;
}

.run-svg-icon {
  display: inline-block !important;
  width: 22px !important;
  height: 22px !important;
  flex: 0 0 22px !important;
  background-color: currentColor !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;
  -webkit-mask-repeat: no-repeat !important;
  mask-repeat: no-repeat !important;
  -webkit-mask-position: center !important;
  mask-position: center !important;
  -webkit-mask-size: contain !important;
  mask-size: contain !important;
  vertical-align: middle !important;
  pointer-events: none !important;
}

.run-svg-play {
  -webkit-mask-image: url("../lib/svg/play.svg") !important;
  mask-image: url("../lib/svg/play.svg") !important;
}

.run-svg-pause {
  -webkit-mask-image: url("../lib/svg/pause.svg") !important;
  mask-image: url("../lib/svg/pause.svg") !important;
}

.run-svg-stop {
  -webkit-mask-image: url("../lib/svg/stop.svg") !important;
  mask-image: url("../lib/svg/stop.svg") !important;
}

.run-svg-app {
  -webkit-mask-image: url("../lib/svg/app.svg") !important;
  mask-image: url("../lib/svg/app.svg") !important;
}
#runBtn{margin-top: -2px;}

#pauseBtn,
#stopBtn {
  margin-top: 0 !important;
  font-size: inherit !important;
}

/* Right menu links/items: remove underline decoration */
.aiigle-info-menu a,
.aiigle-info-menu a:hover,
.aiigle-info-menu a:focus,
.aiigle-info-menu a:active,
.aiigle-info-item,
.aiigle-info-item:hover,
.aiigle-info-item:focus,
.aiigle-info-item:active,
.aiigle-info-legal a,
.aiigle-info-legal a:hover,
.aiigle-info-legal a:focus,
.aiigle-info-legal a:active {
  text-decoration: none !important;
}
.logo > .beta {font-size: 9px; float:right}
