layout.css
9 KB
/* 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;}
}