.admin-layout-v2{min-width:1024px}.admin-layout-v2 .ant-layout-header{position:sticky;top:0;z-index:10;box-shadow:0 2px 8px #0000000f}.admin-layout-v2 .ant-layout-sider{box-shadow:2px 0 8px #0000000f}.admin-layout-v2 .ant-menu-item{height:48px;line-height:48px;margin:4px 8px;border-radius:8px}.admin-layout-v2 .ant-menu-item-selected{background:#e3f2fd!important;color:#1976d2!important}.admin-layout-v2 .ant-menu-item:hover{background:#f5f5f5}.admin-layout-v2 .ant-layout-content{margin:24px 0;background:#fff}@media(max-width:1023px){.admin-layout-v2:before{content:"Admin panel requires desktop. Minimum width: 1024px";position:fixed;inset:0;background:#fff;display:flex;align-items:center;justify-content:center;z-index:9999;font-size:18px;color:#666;text-align:center;padding:24px}}.admin-layout-v2 ::-webkit-scrollbar{width:8px;height:8px}.admin-layout-v2 ::-webkit-scrollbar-track{background:#f1f1f1}.admin-layout-v2 ::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.admin-layout-v2 ::-webkit-scrollbar-thumb:hover{background:#555}.sale-layout{min-height:100vh;background-color:#f0f2f5;position:relative;padding-bottom:60px}.sale-header{background:#fff;padding:0 16px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 4px #00000014;position:sticky;top:0;z-index:10;height:56px;line-height:56px}.header-brand .brand-text{font-size:18px;font-weight:600;color:#52c41a}.sale-content{padding:8px;overflow-y:auto}.sale-bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;box-shadow:0 -1px 4px #00000014;z-index:100}.sale-bottom-nav .bottom-menu{display:flex;justify-content:space-around;border-bottom:none;line-height:1.2}.sale-bottom-nav .ant-menu-item{flex:1;text-align:center;padding:8px 0!important;height:60px;display:flex;flex-direction:column;justify-content:center;align-items:center}.sale-bottom-nav .ant-menu-item:after{display:none}.bottom-nav-text{font-size:10px}.sale-bottom-nav .ant-menu-item-selected{color:#52c41a!important}@media(min-width:768px){.sale-layout{padding-bottom:0}.sale-bottom-nav{display:none}.sale-content{padding:24px}}.giam-sat-layout{min-height:100vh;background-color:#f5f6fa;position:relative;padding-bottom:60px}.giam-sat-header{background:#fa8c16;padding:0 16px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #00000026;position:sticky;top:0;z-index:100;height:56px;line-height:56px}.header-brand-mobile{display:flex;align-items:center;gap:8px}.brand-logo-small{width:32px;height:32px;background:#ffffff40;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px}.brand-text-mobile{font-size:16px;font-weight:600;color:#fff}.header-actions-mobile{display:flex;align-items:center;gap:16px}.header-icon-mobile{font-size:20px;color:#fff;cursor:pointer}.giam-sat-content{padding:16px 16px 80px;max-width:768px;margin:0 auto;width:100%}.giam-sat-bottom-nav{position:fixed;bottom:0;left:0;right:0;height:60px;background:#fff;border-top:1px solid #e8e8e8;display:flex;box-shadow:0 -2px 8px #00000014;z-index:100}.bottom-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;color:#8c8c8c;font-size:10px;font-weight:400;transition:all .2s;border-top:2px solid transparent}.bottom-nav-tab.active{color:#fa8c16;background:#fff7e6;font-weight:600;border-top:2px solid #fa8c16}.tab-icon{font-size:20px}.tab-label{margin-top:-2px}.gs-page-title{margin-bottom:16px;font-weight:700;font-size:20px;color:#333}.gs-card{border-radius:12px;margin-bottom:16px;box-shadow:0 2px 8px #0000000f;border:none}.base-layout-sidebar{background:#001529}.base-layout-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px}.base-layout-content{min-height:280px}.ky-thuat-layout{min-height:100vh;background-color:#f0f2f5;position:relative;padding-bottom:60px}.ky-thuat-header{background:#fff;padding:0 16px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 4px #00000014;position:sticky;top:0;z-index:10;height:56px;line-height:56px}.header-brand .brand-text{font-size:18px;font-weight:600;color:#13a8a8}.header-icon{font-size:20px;color:#595959;cursor:pointer}.ky-thuat-content{padding:16px;overflow-y:auto}.ky-thuat-bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;box-shadow:0 -1px 4px #00000014;z-index:100}.ky-thuat-bottom-nav .bottom-menu{display:flex;justify-content:space-around;border-bottom:none;line-height:1.2}.ky-thuat-bottom-nav .ant-menu-item{flex:1;text-align:center;padding:8px 0!important;height:60px;display:flex;flex-direction:column;justify-content:center;align-items:center}.ky-thuat-bottom-nav .ant-menu-item:after{display:none}.bottom-nav-item{display:flex;flex-direction:column;align-items:center}.bottom-nav-icon{font-size:20px;margin-bottom:4px}.bottom-nav-text{font-size:11px}.ky-thuat-bottom-nav .ant-menu-item-selected{color:#13a8a8!important}.ky-thuat-page-title{margin-bottom:16px;font-weight:600}.ky-card{border-radius:8px;margin-bottom:12px;box-shadow:0 1px 2px #0000000d}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:24px}.login-content{width:100%;max-width:900px}.login-card{background:#fffffffa;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:48px 32px}.login-header{text-align:center;margin-bottom:48px}.login-title{margin-bottom:8px!important;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:48px!important;font-weight:700!important}.login-subtitle{font-size:18px;color:#666;font-weight:500}.role-selection-section{margin-bottom:32px}.section-title{text-align:center;margin-bottom:8px!important;color:#333}.section-description{display:block;text-align:center;font-size:14px}.role-card{height:100%;transition:all .3s ease;border-radius:12px;overflow:hidden}.role-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000026}.role-card .ant-card-body{padding:24px}.role-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:#0000000a;border-radius:12px;margin-bottom:16px}.login-footer{text-align:center;margin-top:32px;padding-top:24px;border-top:1px solid #f0f0f0}@media(max-width:768px){.login-card{padding:32px 24px}.login-title{font-size:36px!important}.login-subtitle{font-size:16px}}html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}:root{--primary-color: #1890ff;--success-color: #52c41a;--warning-color: #faad14;--error-color: #f5222d;--text-color: rgba(0, 0, 0, .85);--text-secondary: rgba(0, 0, 0, .45);--border-color: #d9d9d9;--background-color: #f0f2f5}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}
