/* WorkersPanel Layout */
:root{
  --sidebar-w: 270px;
}

html,body{
  max-width:100%;
  overflow-x:hidden;
}

body{
  background:var(--bg-main);
}

.app-container{
  display:flex;
  min-height:100vh;
  background:var(--bg-main);
}

.sidebar-backdrop{
  display:none;
}

.sidebar{
  width:var(--sidebar-w);
  flex:0 0 var(--sidebar-w);
  background:var(--bg-panel);
  border-right:1px solid var(--border);
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:14px;
  position:fixed;
  inset:0 auto 0 0;
  z-index:300;
  overflow-y:auto;
  overflow-x:hidden;
  box-shadow:10px 0 34px rgba(0,0,0,.30);
}

.sidebar-header{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  flex-direction:column;
  padding-bottom:12px;
  border-bottom:1px solid var(--border);
}

.sidebar-logo-link{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:var(--text-main);
  width:100%;
  padding:8px;
  border-radius:12px;
  transition:background .2s ease;
}
.sidebar-logo-link:hover{background:var(--bg-hover);}

.sidebar-logo{
  display:flex;
  align-items:center;
  justify-content:center;
  width:110px;
  height:110px;
  flex-shrink:0;
}

.sidebar-logo-img{
  width:110px;
  height:110px;
  border-radius:0;
  object-fit:contain;
  background:transparent;
  border:none;
  padding:0;
  box-shadow:none;
}

.logo-icon{
  width:80px;
  height:80px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#0f0f0f;
  border:2px solid var(--accent);
  font-weight:800;
  font-size:2rem;
  color:var(--accent);
}

.logo-text{
  font-weight:800;
  letter-spacing:.3px;
  color:var(--accent);
  font-size:1.05rem;
  text-align:center;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
}

.sidebar-nav{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-top:6px;
}

.nav-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 12px;
  border-radius:12px;
  color:var(--text-main);
  text-decoration:none;
  border:1px solid transparent;
  font-weight:650;
  font-size:.95rem;
  position:relative;
  min-height:44px;
}
.nav-item .icon{
  width:22px;
  text-align:center;
  opacity:.95;
  flex-shrink:0;
}
.nav-item:hover{background:var(--bg-hover);}
.nav-item.active{
  background:var(--accent-soft);
  border-color:rgba(255,140,26,.35);
}
.nav-item.active::before{
  content:"";
  position:absolute;
  left:-1px;
  top:8px;
  bottom:8px;
  width:4px;
  border-radius:999px;
  background:var(--accent);
}

.main-area{
  flex:1;
  display:flex;
  flex-direction:column;
  min-width:0;
  margin-left:var(--sidebar-w);
}

.main-content{
  flex:1;
  padding:22px 24px;
  min-width:0;
  width:100%;
  max-width:1400px;
  margin:0 auto;
}

.page-header-simple{
  background:rgba(26, 26, 26, 0.78);
  border-bottom:1px solid rgba(255,255,255,0.08);
  padding:14px 24px;
  position:sticky;
  top:0;
  z-index:200;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  min-height:var(--topbar-h);
  box-shadow:0 10px 30px rgba(0,0,0,0.20);
  backdrop-filter:blur(10px);
}

.header-left,
.header-right{
  display:flex;
  align-items:center;
  gap:12px;
}
.header-left{
  min-width:0;
  flex:1 1 auto;
}
.header-right{margin-left:auto;}

.header-logo-link{display:inline-flex;align-items:center;}
.header-logo{
  width:48px;
  height:48px;
  border-radius:0;
  object-fit:contain;
  background:transparent;
  border:none;
  padding:0;
  box-shadow:none;
  flex-shrink:0;
}
.company-name{
  font-weight:800;
  font-size:1.1rem;
  color:var(--accent);
  letter-spacing:.3px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.page-separator{color:var(--text-muted);font-weight:300;font-size:1.1rem;}
.page-name{
  font-weight:700;
  font-size:1.1rem;
  color:var(--text-main);
  letter-spacing:.2px;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.mobile-menu-toggle{
  display:none !important;
  width:44px;
  height:44px;
  border-radius:10px;
  border:1px solid var(--border);
  background:var(--bg-card);
  color:var(--text-main);
  font-size:1.4rem;
  cursor:pointer;
  transition:all .2s ease;
}
.mobile-menu-toggle:hover{background:var(--bg-hover);border-color:var(--accent);}

.user-name{font-weight:700;color:var(--text-main);font-size:.9rem;}
.user-role{color:var(--text-muted);font-size:.8rem;}
.user-avatar{
  width:36px;
  height:36px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg, rgba(255,140,26,.2), rgba(255,111,0,.2));
  border:2px solid var(--accent);
  color:var(--accent);
  font-weight:900;
  font-size:1rem;
  flex-shrink:0;
}

.header-nav{
  display:flex;
  gap:0;
  border-bottom:1px solid var(--border);
  padding:0 24px;
  background:rgba(26, 26, 26, 0.72);
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  position:sticky;
  top:var(--topbar-h);
  z-index:190;
  backdrop-filter:blur(10px);
  scrollbar-width:none;
}
.header-nav::-webkit-scrollbar{display:none;}
.header-nav + .main-content{padding-top:18px;}

.header-nav-item{
  display:inline-flex;
  align-items:center;
  min-height:48px;
  padding:12px 20px;
  text-decoration:none;
  color:var(--text-muted);
  border-bottom:3px solid transparent;
  white-space:nowrap;
  transition:all .2s ease;
  font-size:.95rem;
  font-weight:600;
}
.header-nav-item:hover{color:var(--text-main);border-bottom-color:var(--accent-soft);}
.header-nav-item.active{color:var(--text-main);border-bottom-color:var(--accent);}

.header-logo.mobile-only,
.mobile-only{display:none !important;}
.header-nav.header-nav--sub{margin:6px 0 14px;padding:0 12px;background:var(--bg-main);border-bottom:1px solid var(--border);}
.header-nav.header-nav--sub .header-nav-item{padding:10px 16px;font-size:.92rem;}

@media (max-width: 900px){
  .desktop-only{display:none !important;}
  .mobile-only,
  .header-logo.mobile-only{display:block !important;}

  .app-container{flex-direction:column;}

  .sidebar{
    width:min(86vw, 330px);
    flex:0 0 auto;
    border-right:1px solid var(--border);
    height:100vh;
    padding:14px;
    left:0;
    transform:translateX(-110%);
    transition:transform .22s ease;
    will-change:transform;
  }
  .sidebar.open{transform:translateX(0);}
  .sidebar-backdrop{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.45);
    opacity:0;
    pointer-events:none;
    transition:opacity .2s ease;
    z-index:250;
    display:block;
  }
  .sidebar-backdrop.open{
    opacity:1;
    pointer-events:auto;
  }

  .sidebar-header{flex-direction:row;justify-content:flex-start;gap:12px;}
  .sidebar-logo-link{flex-direction:row;justify-content:flex-start;gap:12px;padding:4px;}
  .sidebar-logo,
  .sidebar-logo-img,
  .logo-icon{width:48px;height:48px;}
  .logo-text{display:inline-block;text-align:left;font-size:1rem;}

  .mobile-menu-toggle{display:inline-flex !important;align-items:center;justify-content:center;}

  .main-area{margin-left:0 !important;width:100%;}
  .page-header-simple{padding:12px 16px;}
  .company-name,
  .page-name{font-size:.92rem;}
  .page-separator{font-size:.9rem;}
  .main-content{padding:18px 16px;}

  .header-nav{top:var(--topbar-h);padding:0 12px;}
  .header-nav-item{padding:10px 16px;font-size:.88rem;min-height:44px;}
}

@media (max-width: 768px){
  .main-content{padding:14px;}
  .nav-item{font-size:.9rem;padding:10px;}
  .card{padding:14px;}
}

@media (max-width: 480px){
  .main-content{padding:12px;}
  .page-header-simple{padding:10px 12px;}
  .header-nav{padding:0 8px;}
  .header-nav-item{padding:8px 12px;font-size:.82rem;min-height:40px;}
  .user-avatar{width:34px;height:34px;font-size:.85rem;}
  .nav-item{padding:9px 8px;font-size:.86rem;}
  .nav-item .icon{width:20px;}
  .btn{padding:10px 14px;font-size:.9rem;min-height:44px;}
  .input,select,textarea{font-size:16px;}
}

/* 5.0.12 layout hardening: keep shell stable on desktop/tablet/mobile */
.app-container,.main-area,.main-content{min-width:0;}
.sidebar{overscroll-behavior:contain;}
.page-header-simple{width:100%;}
.header-left{overflow:hidden;}
.header-right{flex:0 0 auto;}
.header-tools .dropdown{position:relative;}
.header-tools .dropdown-menu{z-index:5000;}
.header-nav{max-width:100%;}
.header-nav-item{flex:0 0 auto;}
.main-content img,.main-content table{max-width:100%;}
.table-wrap{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;}
@media (max-width:900px){
  .sidebar{top:0;bottom:0;right:auto;max-width:330px;box-shadow:18px 0 60px rgba(0,0,0,.45);}
  body.sidebar-open .sidebar{transform:translateX(0);}
  body.sidebar-open .sidebar-backdrop{opacity:1;pointer-events:auto;}
  .page-header-simple{position:sticky;top:0;}
  .header-left{gap:8px;}
  .header-right{gap:8px;}
  .header-bell,.header-drop-toggle,.mobile-menu-toggle{min-width:42px;min-height:42px;}
}
@media (max-width:560px){
  .page-header-simple{align-items:center;}
  .page-name{max-width:42vw;}
  .header-tools{gap:6px;}
  .dropdown-menu.app-dropdown{position:fixed!important;right:8px!important;left:8px!important;top:58px!important;transform:none!important;width:auto;max-width:none!important;}
}
