 /* public/css/desktop.css */
body, html { margin:0; padding:0; height:100%; overflow: hidden; font-family: var(--fontFamily); font-size: var(--fontSize); }
#desktop { position:relative; height:100vh; overflow:hidden; background-size:var(--theme-desktop-background-size); background-repeat: no-repeat; background-position: center; touch-action: none; }

#windows { z-index: 1; position:absolute; inset:0; padding:8px; box-sizing:border-box; }
.window { min-width:250px; min-height:250px; position:absolute; width: 800px; height: 600px; border-radius:6px; box-shadow: 0 6px 20px rgba(0,0,0,0.4); overflow:hidden; top:50px; left:50px; display:flex; flex-direction:column; resize:none; }
.window-titlebar { padding: 0 0 1px 0; height: auto;  display:flex; justify-content:space-between; align-items:center; }
.window-titlebar .title { display: flex; align-items: center; min-width: 0; flex: 1; overflow: hidden; }
.window-titlebar .window-title { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-left:8px; }

.window-icon { height: 12px; background-size:contain; transform: translate(1px, -1px); background-repeat: no-repeat; background-position: left; background-color: rgb(144, 179, 144); padding:4px;border-radius: 6px;}
.window .controls { display: flex; flex-shrink: 0;}
.window .controls button { transition: background-color var(--times-transition-colors), color var(--times-transition-colors); padding: 2px 10px; border:none;}
.window-content { display: flex; flex-direction: column; flex:1; padding:8px; overflow: auto; }
.window[class="max"] .window-resize-handle { display: none; }

.window-resize-s { position: absolute; left: 8px; right: 8px; height: 8px; z-index: 10; }
.window-resize-n { position: absolute; left: 8px; right: 16px; height: 8px; z-index: 10; }
.window-resize-n { top: -4px;cursor: var(--theme-cursor-resize-vertical); }
.window-resize-s { bottom: -4px;cursor: var(--theme-cursor-resize-vertical); }

.window-resize-w { position: absolute;top: 8px;bottom: 8px;width: 8px;z-index: 10; }
.window-resize-e { position: absolute;top: 16px;bottom: 8px;width: 8px;z-index: 10; }
.window-resize-e { right: -4px;cursor: var(--theme-cursor-resize-horizontal); }
.window-resize-w { left: -4px;cursor: var(--theme-cursor-resize-horizontal); }

.window-resize-nw, .window-resize-se, .window-resize-sw { position: absolute;width: 16px;height: 16px;z-index: 11; }
.window-resize-ne { position: absolute;width: 8px;height: 8x;z-index: 11; }
.window-resize-ne { top: -3px;right: -3px;cursor: var(--theme-cursor-resize-45); }
.window-resize-nw { top: -6px;left: -6px;cursor: var(--theme-cursor-resize-270); }
.window-resize-se { bottom: -6px;right: -6px;cursor: var(--theme-cursor-resize-270); }
.window-resize-sw { bottom: -6px;left: -6px;cursor: var(--theme-cursor-resize-45); }

#taskbar { z-index: 2; position: absolute; width:100%; bottom:0; left:0; height:auto; overflow:visible; display:flex; flex: 0 0 auto;  min-width:0; align-items:center; padding:0 8px; box-sizing:border-box; }
#start-btn { transition: background-color var(--times-transition-colors) ease; padding: 5px 12px; border-radius: 5px; border: none; margin-right:8px; }
#taskbar-windows { display:flex; gap:6px; align-items:center; flex:1; overflow-y:hidden;overflow-x: auto; min-width: 0;scrollbar-width: thin;  }
.taskbar-item {  display: flex;  position: relative; padding:4px 10px; border-radius:4px; }
.taskbar-item::before { content: ''; position: absolute; bottom:1px; left:50%; width:40%; height: 4px; border-radius:4px; transform:translateX(-50%) scaleX(0); transform-origin:center; transition:transform var(--times-transition-colors) ease; }
.taskbar-item.focus::before { transform: translateX(-50%) scaleX(1); }

.notify-button { margin-left:auto; flex: 0 0 auto; display: flex; align-items: center; justify-content: center;  }
.notify-button.resume, .notify-button.pulse { animation: pulse 1.5s infinite; animation-play-state: running; }
.notify-button.pause, .notify-button.pause *, .notify-button.active, .notify-button.active * { animation-play-state: paused; } 


@keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}


.hidden { opacity: 0; pointer-events: none; }

/* Open submenu vertical */
#start-menu { z-index: 2; transition: opacity var(--times-transition-opacity); display:flex; flex-direction:column; position: absolute; bottom: auto; left: 8px; width: auto; min-width: 300px; border-radius: 8px; overflow: hidden; }
.start-header { display: flex; align-items: center; padding: 8px; font-weight: 600; }
.start-header > img { height: 24px; width: 24px; margin-right: 5px; }
.start-list { list-style: none; margin: 0; padding: 8px 0; height: 60vh; overflow-y: auto; }
.start-item { padding: 8px 12px 16px 20px; display: flex; gap: 8px; transition: background var(--times-transition-colors); border-radius: 4px; }
.start-item:not(:has(.submenu)) { padding: 12px;align-items:center; }
.start-icon, #start-menu-icon { height: 20px; width: 20px; border-radius: 8px; padding:4px; }
.menu-label { display: block; margin-top: 4px; padding-bottom: 0; margin-left: 26px }
.start-item.has-submenu { position: relative; display: flex; flex-direction: column; padding-bottom: 8px; }
.start-item.has-submenu > .submenu { width: 100%; list-style: none; padding-left: 2px; max-height: 0; overflow: hidden; transition: max-height var(--times-transition-transform) ease; margin: 2px 0 0 8px; }

.start-item-sys-container { position: relative; left:0; bottom: -10px; padding: 5px 0px; width:100%; display:flex; height:30px; flex-direction:row; justify-content:flex-end; }
.start-sys-item { margin: 0 10px 0 8px !important; }

.start-submenu-head { position: relative; margin-left: 16px; height:32px; display:flex; flex-direction: row; align-items: center; gap:8px; }
.start-item.has-submenu > .menu-label::after { content: ""; position: absolute; right: 14px;  transform: translateY(50%) rotate(0deg); border: 5px solid transparent; border-top-color: #aaa; transition: transform var(--times-transition-transform); }
.start-item.has-submenu.open > .menu-label::after { content: ""; position: absolute; right: 14px;  transform: translateY(50%) rotate(180deg); border: 5px solid transparent; border-top-color: #aaa; transition: var(--times-transition-transform); }
.start-item.has-submenu.open > .submenu { max-height: 500px; }
.start-item.has-submenu > .submenu li { opacity: 0; transform: translateY(-5px); transition: opacity var(--times-transition-opacity), transform 0.2s; }
.start-item.has-submenu.open > .submenu li { opacity: 1; transform: translateY(0); }

img.icon { width: auto; height:20px; object-fit: contain; filter: var(--theme-notifybubble-filter); transform: translate(2px, 2px) }




@media (max-width: 768px) {

  body, html {
    overflow: auto;
  }

  #desktop {
    height: 100dvh;
  }

  /* Fenster = Fullscreen */
  .window {
    width: 100% !important;
    height: calc(100% - 54px) !important;
    top: 0 !important;
    left: 0 !important;
    border-radius: 0;
    resize: none;
  }

  .window-resize-handle {
    display: none !important;
  }

  .window-titlebar {
    height: 29px;
    padding: 0 0px;
  }

  .window-content {
    padding: 0px;
  }

  /* Taskbar größer für Touch */
  #taskbar {
    padding: 0 6px;
    overflow: hidden;
    z-index: 9999;
  }

  #start-btn {
    padding: 4px 8px;
    font-size: 16px;
  }

  .taskbar-item {
    padding: 0 5px 4px 0;
    top: 0px;
    white-space:nowrap; 
    text-overflow:ellipsis;
  }

.start-list { list-style: none; margin: 0; padding: 8px 0; height: 100%; overflow-y: auto; }

#start-menu {
    bottom: 50px !important;
    height: calc(100dvh - 65px) !important;
    width: calc(100dvw - 5px);
    left: 0 !important;
    border-radius: 0 !important;
  } */
  
  .start-item {
    padding: 14px;
    font-size: 16px;
  }

  .start-icon {
    height: 24px;
    width: 24px;
  }

  .start-item.has-submenu > .menu-label { margin: 8px 0 0 40px; }

  .start-item-sys-container { margin:auto; bottom: -10px; }



  /* Buttons besser klickbar */
  .window .controls button {
    padding: 10px 12px;
  }

  /* Notify Button */
  .notify-button {
    padding: 8px;
  }

}

@media (max-width: 1000px) AND (orientation: landscape) {

  body, html {
    overflow: auto;
  }

  #desktop {
    height: 100dvh;
  }
  /* Fenster IMMER fullscreen */
  .window {
    width: 100% !important;
    height: calc(100dvh - 46px) !important;
    top: 0 !important;
    left: 0 !important;
    border-radius: 0 !important;
  }

  /* Resize komplett aus */
  .window-resize-handle {
    display: none !important;
  }

  .window-titlebar {
    height: 30px;
    padding: 0 0px;
  }


  /* Startmenü bis ganz oben */
  #start-menu {
    bottom: 44px !important;
    height: calc(100dvh - 60px) !important;
    width: 300px;
    max-width: 35dvw;
    left: 0 !important;
    border-radius: 0 !important;
  }

  /* Taskbar bleibt sichtbar, aber oben drüber sauber */
  #taskbar {
    z-index: 9999;
  }

  /* Startliste nutzt volle Höhe */
  .start-list {
    height: 100%;
  }

  .start-item-sys-container { bottom: -10px;}


  .start-item.has-submenu > .menu-label { margin: 8px 0 0 28px; }
}