.login-container{min-height:100vh;min-height:100dvh;width:100%;display:flex;align-items:center;justify-content:center;padding:24px;overflow-y:auto;background:radial-gradient(circle at 50% 0%,#0895d13d,#0895d100 34%),linear-gradient(135deg,#071827,#0b2740)}.login-box,.login-box *{box-sizing:border-box}.login-box{width:100%;max-width:560px;background:#fff;border:1px solid rgba(216,226,236,.92);border-radius:18px;overflow:hidden;box-shadow:0 28px 80px #08172647}.login-header{padding:34px 30px 26px;text-align:center;color:#fff;background:linear-gradient(180deg,#ffffff14,#fff0 34%),linear-gradient(135deg,#071827,#0b2740)}.login-logo{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:12px}.login-logo-mark{display:inline-flex;align-items:center;justify-content:center;width:76px;height:76px;border-radius:20px;border:1px solid rgba(186,226,245,.7);background:#fffffff5;box-shadow:0 18px 44px #0895d133;overflow:hidden}.login-logo-mark img{width:70px;height:70px;object-fit:contain}.login-logo h1{margin:0;font-size:31px;font-weight:850;line-height:1.1}.subtitle{margin:0;font-size:14px;opacity:.84}.login-language-switcher{margin:16px auto 0;border-color:#bae2f547;background:#ffffff14}.login-language-switcher button{color:#ffffffc7}.login-language-switcher button.active{background:#fff;color:#056da0;box-shadow:none}.server-config-panel{padding:16px 20px;border-bottom:1px solid #e5e7eb;background:#f5fbff}.server-config-panel h3{margin:0 0 6px;font-size:14px;color:#1a1a2e}.server-config-hint{margin:0 0 10px;font-size:12px;line-height:1.5;color:#4b5563}.server-config-input-row input{width:100%;padding:11px 12px;border:1px solid #cfd8e3;border-radius:8px;font-size:13px}.server-config-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.server-btn{border:none;border-radius:9px;padding:9px 12px;background:#0f7ab8;color:#fff;font-size:12px;font-weight:600;cursor:pointer}.server-btn.secondary{background:#24445d}.server-btn:disabled{opacity:.7;cursor:not-allowed}.server-config-active,.server-config-message{margin:8px 0 0;font-size:12px;color:#1f2937;word-break:break-word}.login-content{padding:30px 28px}.login-content h2{margin:0 0 8px;text-align:center;font-size:24px;color:#1a1a2e}.login-hint{margin:0 0 22px;text-align:center;color:#64748b;font-size:14px;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:18px;margin-top:6px}.form-group{margin:0}.form-group label{display:block;margin-bottom:10px;font-size:14px;font-weight:600;color:#334155}.form-group input{width:100%;padding:14px;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus{outline:none;border-color:#0aa0da;box-shadow:0 0 0 3px #0895d124}.remember-login-row{display:inline-flex;align-items:center;gap:10px;margin-top:-4px;color:#334155;font-size:14px;font-weight:600;cursor:pointer}.remember-login-row input{width:18px;height:18px;accent-color:#0a8fc4;cursor:pointer}.error-message{margin:0;padding:12px 16px;border-left:4px solid #e53935;border-radius:10px;background:#ffebee;color:#e53935;font-size:14px;line-height:1.45}.active-session-conflict{display:flex;flex-direction:column;gap:12px;padding:14px;border:1px solid #facc15;border-radius:10px;background:#fefce8;color:#713f12;font-size:13px;line-height:1.45}.active-session-conflict div{display:flex;flex-direction:column;gap:4px}.active-session-conflict span{overflow-wrap:anywhere}.session-replace-btn{min-height:42px;border:none;border-radius:9px;background:#92400e;color:#fff;font-weight:700;cursor:pointer}.session-replace-btn:disabled{opacity:.7;cursor:not-allowed}.login-btn{width:100%;min-height:52px;padding:15px 16px;border:none;border-radius:11px;background:linear-gradient(135deg,#0aa0da,#056da0);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 26px #0895d142}.login-btn:disabled{opacity:.72;cursor:not-allowed}.login-footer{padding:18px 20px;text-align:center;background:#f8fafc;border-top:1px solid #e2e8f0}.login-footer p{margin:0;font-size:12px;color:#64748b}@media (max-width: 768px){.login-container{padding:14px}.login-header{padding:30px 22px 24px}.login-logo h1{font-size:25px}.login-logo-mark{width:66px;height:66px}.login-logo-mark img{width:61px;height:61px}.login-content{padding:24px 20px}}@media (max-width: 520px){.login-container{padding:10px}.login-box{border-radius:16px}.login-header{padding:24px 18px 20px}.login-logo{gap:10px}.login-logo h1{font-size:22px}.subtitle{font-size:13px}.server-config-panel{padding:14px 16px}.login-content{padding:20px 16px}.login-content h2{font-size:20px}.form-group input{font-size:16px}.login-footer{padding:16px}}@media (max-height: 720px) and (min-width: 560px){.login-container{align-items:flex-start;padding:12px}.login-box{max-width:640px;border-radius:16px}.login-header{padding:20px 24px 18px}.login-logo{gap:12px;margin-bottom:8px}.login-logo-mark{width:62px;height:62px;border-radius:16px}.login-logo-mark img{width:56px;height:56px}.login-logo h1{font-size:28px}.subtitle{font-size:13px}.login-content{padding:22px 24px}.login-content h2{font-size:22px;margin-bottom:6px}.login-hint{margin-bottom:16px;font-size:13px}.login-footer{padding:12px 16px}}@media (max-height: 560px) and (min-width: 560px){.login-header{padding:16px 22px 14px}.login-logo-mark{width:54px;height:54px}.login-logo-mark img{width:49px;height:49px}.login-logo h1{font-size:25px}.login-content{padding:18px 22px}}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;background:#fff;min-width:300px;animation:slideIn .3s ease-out;pointer-events:auto;transition:all .3s ease}.toast:hover{transform:translate(-5px);box-shadow:0 6px 16px #0003}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;gap:12px;flex:1}.toast-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:14px;font-weight:700;flex-shrink:0}.toast-message{flex:1;font-size:14px;line-height:1.5;color:#333}.toast-close{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:#999;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;flex-shrink:0}.toast-close:hover{background:#0000000d;color:#333}.toast-success{border-left:4px solid #10b981}.toast-success .toast-icon{background:#d1fae5;color:#10b981}.toast-error{border-left:4px solid #ef4444}.toast-error .toast-icon{background:#fee2e2;color:#ef4444}.toast-warning{border-left:4px solid #f59e0b}.toast-warning .toast-icon{background:#fef3c7;color:#f59e0b}.toast-info{border-left:4px solid #3b82f6}.toast-info .toast-icon{background:#dbeafe;color:#3b82f6}@media (max-width: 768px){.toast-container{top:10px;right:10px;left:10px;max-width:none}.toast{min-width:auto;width:100%}}:root{--primary-color: #0895d1;--primary-dark: #056da0;--primary-soft: #e7f6fd;--success-color: #138a5b;--warning-color: #c47a12;--danger-color: #c93632;--info-color: #0f7ab8;--bg-color: #eef3f8;--card-bg: #ffffff;--text-primary: #102033;--text-secondary: #647386;--border-color: #d8e2ec;--sidebar-width: 288px;--mobile-bottom-nav-height: 0px;--surface-shadow: 0 12px 34px rgba(15, 32, 51, .08);--surface-shadow-strong: 0 24px 70px rgba(8, 23, 38, .18)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-color);color:var(--text-primary);line-height:1.5;accent-color:var(--primary-color)}.app-container{display:flex;min-height:var(--app-height)}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,#ffffff12,#fff0 18%),linear-gradient(180deg,#071827,#0b2740 48%,#0a1f33);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:var(--app-height);overflow-y:auto;z-index:100;transition:transform .3s ease;border-right:1px solid rgba(174,210,230,.16);box-shadow:14px 0 36px #06132029}.sidebar-header{padding:22px 20px 18px;border-bottom:1px solid rgba(209,232,244,.14);cursor:pointer}.app-logo,.logo{display:flex;align-items:center;gap:12px}.app-logo-texts,.logo-texts{display:flex;flex-direction:column;gap:4px;min-width:0}.app-logo-mark{width:58px;height:58px;display:inline-flex;align-items:center;justify-content:center;border-radius:16px;background:transparent;border:none;box-shadow:none;overflow:hidden;flex-shrink:0}.app-logo-mark img{width:100%;height:100%;object-fit:cover;transform:scale(1.48) translateY(7%);transform-origin:center}.logo-icon{font-size:32px}.app-logo-text,.logo-text{font-size:20px;font-weight:800;letter-spacing:0;color:#f8fbff;line-height:1.05}.user-info{display:flex;flex-direction:column;gap:2px}.user-name{font-size:13px;font-weight:600;color:#ffffffe6}.user-role{font-size:11px;color:#fff9}.sidebar-profile-card{margin:14px 14px 6px;padding:12px;border:1px solid rgba(202,232,247,.18);border-radius:10px;background:#ffffff12;box-shadow:inset 0 1px #ffffff14}.sidebar-profile-title{font-size:12px;letter-spacing:0;text-transform:uppercase;color:#ffffffb8;margin-bottom:10px}.sidebar-profile-list{display:grid;gap:8px}.sidebar-profile-row{display:flex;flex-direction:column;gap:2px}.sidebar-profile-label{font-size:10px;text-transform:uppercase;color:#ffffff8c;letter-spacing:0}.sidebar-profile-value{font-size:12px;font-weight:600;color:#ffffffeb;word-break:break-word}.sidebar-credentials{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.14)}.sidebar-credentials-toggle{width:100%;border:none;background:transparent;color:inherit;padding:0;display:flex;align-items:center;justify-content:space-between;cursor:pointer}.sidebar-credentials-toggle-icon{font-size:11px;color:#ffffffa6;transition:transform .25s ease}.sidebar-credentials-toggle-icon.open{transform:rotate(180deg)}.sidebar-credentials-collapse{display:grid;grid-template-rows:0fr;opacity:0;transition:grid-template-rows .3s ease,opacity .25s ease}.sidebar-credentials.open .sidebar-credentials-collapse{grid-template-rows:1fr;opacity:1}.sidebar-credentials-form{overflow:hidden;padding-top:10px;display:grid;gap:8px}.sidebar-credentials-title{font-size:11px;text-transform:uppercase;letter-spacing:0;color:#ffffffb8}.sidebar-credentials-label{font-size:11px;color:#ffffffb8}.sidebar-credentials-input{width:100%;border:1px solid rgba(255,255,255,.18);background:#ffffff1a;color:#fff;border-radius:8px;padding:8px 10px;font-size:12px}.sidebar-credentials-input::placeholder{color:#ffffff8c}.sidebar-credentials-input:focus{outline:none;border-color:#4a90d9e6;box-shadow:0 0 0 2px #4a90d940}.sidebar-credentials-submit{margin-top:4px;border:none;border-radius:8px;padding:9px 10px;font-size:12px;font-weight:600;cursor:pointer;color:#fff;background:linear-gradient(135deg,#4a90d9,#357abd)}.sidebar-credentials-submit:disabled{opacity:.7;cursor:not-allowed}.nav-menu{flex:1;padding:14px 12px;display:flex;flex-direction:column;gap:6px}.nav-item{display:flex;align-items:center;gap:12px;min-height:48px;padding:12px 14px;background:transparent;border:1px solid transparent;border-radius:9px;color:#eaf6fcc7;font-size:14px;font-weight:650;cursor:pointer;transition:all .2s;text-align:left;position:relative;width:100%}.nav-item:hover{background:#ffffff14;border-color:#bae2f529;color:#fff}.nav-item.active{background:linear-gradient(135deg,#0aa0da,#056da0);color:#fff;box-shadow:0 12px 26px #0895d147;border-color:#daf4ff42}.nav-item.has-children{justify-content:space-between}.nav-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:#ffffff17;border:1px solid rgba(255,255,255,.08);color:#bdefff;font-size:11px;font-weight:850;line-height:1;text-align:center;flex-shrink:0}.nav-label{flex:1;min-width:0}.nav-arrow{font-size:10px;transition:transform .2s;opacity:.6}.nav-arrow.expanded{transform:rotate(90deg)}.nav-children{padding:6px 0 6px 20px;display:flex;flex-direction:column;gap:4px}.nav-child-item{display:flex;align-items:center;gap:10px;min-height:42px;padding:9px 12px;background:transparent;border:1px solid transparent;border-radius:8px;color:#fff9;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;text-align:left;width:100%}.nav-child-item:hover{background:#ffffff0f;border-color:#ffffff14;color:#fff}.nav-child-item.active{background:#0895d12e;color:#bdefff}.nav-label{flex:1}.sidebar .nav-badge{background:var(--danger-color);color:#fff;font-size:11px;font-weight:700;padding:0 8px;border-radius:10px;min-width:24px;height:20px;text-align:center;display:inline-flex;align-items:center;justify-content:center;line-height:1;font-variant-numeric:tabular-nums}.sidebar-footer{padding:16px 14px;border-top:1px solid rgba(209,232,244,.14)}.quick-stats{display:flex;gap:12px;margin-bottom:12px}.sidebar-footer .sidebar-stat-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 10px;background-color:#ffffff0f;background-image:linear-gradient(180deg,#ffffff1f,#ffffff0a);border:1px solid rgba(255,255,255,.14);box-shadow:inset 0 1px #ffffff14;border-radius:9px;min-height:76px;color:#fff;-moz-appearance:none;appearance:none;-webkit-appearance:none;forced-color-adjust:none}.stat-button{border:none;color:inherit;text-align:center;cursor:pointer;transition:background .2s ease,transform .15s ease}.sidebar-footer .stat-button{color:#fff;-webkit-text-fill-color:#ffffff}.stat-button:hover{background:#ffffff1f}.sidebar-footer .stat-button:hover{background-color:#ffffff24;background-image:linear-gradient(180deg,#fff3,#ffffff14)}.stat-button:active{transform:translateY(1px)}.stat-button:focus-visible{outline:2px solid rgba(255,255,255,.45);outline-offset:2px}.sidebar-footer .sidebar-stat-icon{width:30px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:7px;background:#ffffff1a;color:#bdefff;font-size:10px;font-weight:850;margin-bottom:4px}.sidebar-footer .sidebar-stat-value{display:block;padding:0;margin:0;background:transparent;border-radius:0;font-size:20px;font-weight:700;line-height:1;min-width:2ch;font-variant-numeric:tabular-nums;color:#fff}.sidebar-footer .sidebar-stat-label{font-size:11px;color:#fff9;margin-top:2px;min-height:14px;line-height:1.2}.logout-btn{width:100%;min-height:46px;padding:12px;background:#c936321f;border:1px solid rgba(255,126,122,.28);border-radius:9px;color:#ffc8c5;font-size:14px;font-weight:750;cursor:pointer;transition:all .2s}.logout-btn:hover{background:#c9363233}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:var(--app-height);min-width:0;display:flex;flex-direction:column;background:linear-gradient(180deg,#f7fbff,#f7fbff00 260px),var(--bg-color)}.top-header{background:#ffffffeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:18px 32px;min-height:78px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:50}.header-title{display:flex;align-items:center;gap:12px;min-width:0}.header-brand-mark{display:none;width:38px;height:38px;align-items:center;justify-content:center;border-radius:11px;background:transparent;border:none;padding:0;box-shadow:none;overflow:hidden;flex-shrink:0;cursor:pointer}.header-brand-mark img{width:100%;height:100%;object-fit:cover;transform:scale(1.48) translateY(7%);transform-origin:center}.header-brand-mark:active{transform:scale(.96)}.back-button{background:#0f7ab8;color:#fff;border:none;border-radius:9px;padding:.5rem 1rem;cursor:pointer;font-size:1rem;display:flex;align-items:center;gap:.5rem;transition:all .2s;min-height:44px;font-weight:750}.back-button:hover{background:#056da0;transform:translateY(-1px);box-shadow:0 8px 18px #0895d13d}.back-button:active{transform:translateY(0)}.header-title h1{font-size:25px;color:var(--text-primary);font-weight:800;line-height:1.15;min-width:0}.top-header .header-actions{display:flex;align-items:center;gap:16px;flex-shrink:0}.language-switcher{display:inline-flex;align-items:center;gap:4px;padding:4px;border:1px solid var(--border-color);border-radius:12px;background:#fff}.language-switcher button{min-width:38px;min-height:34px;border:none;border-radius:9px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:800;cursor:pointer}.language-switcher button.active{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;box-shadow:0 8px 18px #0895d138}.language-switcher button:focus-visible{outline:2px solid rgba(8,149,209,.35);outline-offset:2px}.notification-center{position:relative}.notification-trigger{position:relative;display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--border-color);border-radius:13px;background:#fff;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.notification-trigger:hover,.notification-trigger.open{border-color:#a6dff4;background:#effaff;box-shadow:0 10px 24px #0895d11f}.notification-trigger-icon{width:26px;height:26px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:var(--primary-soft);color:var(--primary-dark);font-size:10px;font-weight:850}.top-header .notification-trigger-badge{position:absolute;top:-5px;right:-5px;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 14px #ef444459;line-height:1;font-variant-numeric:tabular-nums}.notification-panel{position:absolute;top:calc(100% + 10px);right:0;width:min(460px,calc(100vw - 32px));max-height:min(72vh,640px);overflow:hidden;border:1px solid #dbe4f0;border-radius:16px;background:#fff;box-shadow:var(--surface-shadow-strong);z-index:120}.notification-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 18px 14px;border-bottom:1px solid #e5edf6;background:linear-gradient(135deg,#f8fbff,#fff)}.notification-panel-header h3{margin:0;font-size:16px;color:var(--text-primary)}.notification-panel-header p{margin:4px 0 0;font-size:13px;color:var(--text-secondary)}.notification-panel-header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.notification-mark-all{border:none;background:none;color:#2563eb;font-size:13px;font-weight:700;cursor:pointer}.notification-mark-all:hover{color:#1d4ed8}.notification-delete-all{border:none;background:none;color:#b91c1c;font-size:13px;font-weight:700;cursor:pointer}.notification-delete-all:hover{color:#991b1b}.notification-panel-body{max-height:calc(min(72vh,640px) - 82px);overflow-y:auto;padding:12px;display:grid;gap:10px}.notification-empty-state{display:grid;place-items:center;gap:10px;padding:32px 20px;color:var(--text-secondary);text-align:center}.notification-empty-icon{font-size:28px}.notification-card{--notification-accent: #3b82f6;--notification-accent-soft: rgba(59, 130, 246, .14);--notification-border: #93c5fd;--notification-hover-border: #60a5fa;--notification-unread-start: #eaf4ff;--notification-unread-end: #f8fbff;--notification-ring: rgba(59, 130, 246, .08);--notification-link: #2563eb;--notification-link-hover: #1d4ed8;--notification-link-underline: rgba(37, 99, 235, .35);display:grid;gap:10px;padding:14px 14px 12px;border:1px solid #e5edf6;border-left:4px solid var(--notification-accent);border-radius:14px;background:#fff;transition:all .2s ease}.notification-card.clickable{cursor:pointer}.notification-card:hover{border-color:var(--notification-hover-border);box-shadow:0 10px 26px #94a3b829;transform:translateY(-1px)}.notification-card.unread{background:linear-gradient(135deg,var(--notification-unread-start) 0%,var(--notification-unread-end) 100%);border-color:var(--notification-border);box-shadow:inset 0 0 0 1px var(--notification-ring)}.notification-card.read{opacity:.88}.notification-card.notification-tone-blue{--notification-accent: #3b82f6;--notification-accent-soft: rgba(59, 130, 246, .14);--notification-border: #93c5fd;--notification-hover-border: #60a5fa;--notification-unread-start: #eaf4ff;--notification-unread-end: #f8fbff;--notification-ring: rgba(59, 130, 246, .08);--notification-link: #2563eb;--notification-link-hover: #1d4ed8;--notification-link-underline: rgba(37, 99, 235, .35)}.notification-card.notification-tone-orange{--notification-accent: #f59e0b;--notification-accent-soft: rgba(245, 158, 11, .14);--notification-border: #fcd34d;--notification-hover-border: #f59e0b;--notification-unread-start: #fff8e6;--notification-unread-end: #fffcf3;--notification-ring: rgba(245, 158, 11, .1);--notification-link: #b45309;--notification-link-hover: #92400e;--notification-link-underline: rgba(180, 83, 9, .35)}.notification-card.notification-tone-red{--notification-accent: #ef4444;--notification-accent-soft: rgba(239, 68, 68, .14);--notification-border: #fca5a5;--notification-hover-border: #ef4444;--notification-unread-start: #fff1f2;--notification-unread-end: #fff8f8;--notification-ring: rgba(239, 68, 68, .1);--notification-link: #b91c1c;--notification-link-hover: #991b1b;--notification-link-underline: rgba(185, 28, 28, .35)}.notification-card.notification-tone-green{--notification-accent: #10b981;--notification-accent-soft: rgba(16, 185, 129, .14);--notification-border: #6ee7b7;--notification-hover-border: #34d399;--notification-unread-start: #ecfdf5;--notification-unread-end: #f5fffb;--notification-ring: rgba(16, 185, 129, .1);--notification-link: #047857;--notification-link-hover: #065f46;--notification-link-underline: rgba(4, 120, 87, .35)}.notification-info,.notification-warning,.notification-success,.notification-assignment,.notification-error,.notification-missing_welder{border-left-color:var(--notification-accent)}.notification-info{--notification-accent: #3b82f6}.notification-warning,.notification-assignment{--notification-accent: #f59e0b}.notification-success{--notification-accent: #10b981}.notification-error,.notification-missing_welder{--notification-accent: #ef4444}.notification-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.notification-card-title-wrap{display:flex;align-items:center;gap:8px;min-width:0}.notification-unread-dot{width:10px;height:10px;border-radius:999px;background:var(--notification-accent);flex-shrink:0;box-shadow:0 0 0 4px var(--notification-accent-soft)}.notification-card-title{color:var(--text-primary);font-size:14px;line-height:1.4}.notification-card.unread .notification-card-title{color:#0f172a}.notification-card-time{color:#64748b;font-size:12px;white-space:nowrap}.notification-card-message{margin:0;color:#475569;font-size:13px;line-height:1.55;white-space:pre-line}.notification-card.unread .notification-card-message{color:#334155}.notification-actions{display:flex;flex-wrap:wrap;gap:8px}.notification-link{border:none;background:none;padding:0;color:var(--notification-link);font-size:13px;font-weight:700;cursor:pointer;text-decoration:underline;text-decoration-color:var(--notification-link-underline);text-underline-offset:3px}.notification-link:hover{color:var(--notification-link-hover)}.notification-link-danger{color:#b91c1c;text-decoration-color:#b91c1c59;margin-left:auto}.notification-link-danger:hover{color:#991b1b}.date-display{font-size:14px;color:var(--text-secondary);text-transform:capitalize}.content-wrapper{flex:1;padding:28px 32px 34px;min-width:0}.content-loading{min-height:clamp(320px,calc(var(--app-height) - 220px),720px);display:grid;place-items:center;gap:14px;padding:32px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;color:var(--text-secondary)}.content-loading-spinner{width:36px;height:36px;border:3px solid rgba(74,144,217,.18);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.view-error-state{min-height:clamp(320px,calc(var(--app-height) - 220px),720px);display:grid;justify-items:center;align-content:center;gap:12px;padding:32px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;text-align:center}.view-error-icon{width:44px;height:44px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#e539351f;color:var(--danger-color);font-size:24px;font-weight:700}.view-error-state h2{font-size:22px;color:var(--text-primary)}.view-error-state p{color:var(--text-secondary);max-width:540px}.view-error-detail{font-size:13px;color:#7b8190;font-family:ui-monospace,SFMono-Regular,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;word-break:break-word}.view-error-retry{border:none;border-radius:10px;padding:10px 16px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;font-size:14px;font-weight:600;cursor:pointer}.view-error-retry:hover{filter:brightness(1.05)}.mobile-menu-toggle{display:none;position:fixed;top:16px;left:16px;z-index:200;background:var(--primary-color);color:#fff;border:none;padding:12px;border-radius:8px;cursor:pointer;font-size:20px;box-shadow:0 2px 8px #0003;transition:all .3s ease}.mobile-menu-toggle:active{transform:scale(.95)}.mobile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:99;animation:fadeIn .3s ease}.mobile-bottom-nav{display:none}.mobile-bottom-nav-item{position:relative;min-width:0;min-height:58px;border:none;border-radius:12px;background:transparent;color:#647386;display:grid;justify-items:center;align-content:center;gap:4px;padding:6px 4px;font:inherit;cursor:pointer}.mobile-bottom-nav-item.active{color:var(--primary-dark);background:#effaff}.mobile-bottom-nav-icon{width:27px;height:24px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:#edf3f8;color:#32546d;font-size:10px;font-weight:850;line-height:1}.mobile-bottom-nav-item.active .mobile-bottom-nav-icon{background:linear-gradient(135deg,#0aa0da,#056da0);color:#fff;box-shadow:0 8px 16px #0895d140}.mobile-bottom-nav-label{width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:10px;font-weight:750;line-height:1.2}.mobile-bottom-nav-badge{position:absolute;top:5px;right:12%;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--danger-color);color:#fff;font-size:10px;font-weight:850;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 12px #c9363247}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;padding:40px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--surface-shadow);text-align:center}.access-denied-icon{width:62px;height:62px;display:inline-flex;align-items:center;justify-content:center;border-radius:18px;background:#c936321a;color:var(--danger-color);font-size:34px;font-weight:850;margin-bottom:24px}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.access-denied h2{font-size:28px;color:var(--danger-color);margin-bottom:16px}.access-denied p{font-size:16px;color:var(--text-secondary);margin-bottom:12px;max-width:500px}.access-denied-hint{font-size:14px;color:var(--text-secondary);font-style:italic;opacity:.8}@media (max-width: 1024px){:root{--sidebar-width: 280px}.main-content{margin-left:0}.sidebar{transform:translate(-100%);box-shadow:18px 0 42px #06132047}.sidebar.open{transform:translate(0)}.mobile-menu-toggle{display:block}.content-wrapper{padding:22px 18px}.top-header{padding:14px 20px 14px 68px;min-height:70px}.header-brand-mark{display:inline-flex}.header-title h1{font-size:20px}.top-header .header-actions{gap:12px}.language-switcher button{min-width:34px;min-height:32px}.notification-panel{right:-8px}}@media (max-width: 768px){:root{--sidebar-width: min(88vw, 360px)}body{font-size:14px}.sidebar{width:var(--sidebar-width);max-width:360px}.sidebar-header{padding:20px 16px}.sidebar-profile-card{margin:10px 8px 4px;padding:10px}.app-logo-mark{width:50px;height:50px}.app-logo-mark img{width:100%;height:100%}.app-logo-text{font-size:18px}.user-name{font-size:12px}.user-role{font-size:10px}.nav-menu{padding:12px 8px}.nav-item{padding:12px 14px;font-size:13px}.nav-icon{width:30px;height:30px;font-size:10px}.nav-child-item{padding:10px 12px;font-size:12px}.content-wrapper{padding:14px 12px 92px}.top-header{padding:max(12px,env(safe-area-inset-top)) 14px 12px;min-height:64px}.header-title{flex-wrap:wrap;gap:8px}.header-title h1{font-size:17px}.back-button{padding:.4rem .8rem;font-size:.9rem;min-height:40px}.date-display{display:none}.quick-stats{flex-direction:column;gap:8px}.sidebar-footer .sidebar-stat-item{padding:10px}.sidebar-footer .sidebar-stat-icon{font-size:16px}.sidebar-footer .sidebar-stat-value{font-size:18px}.sidebar-footer .sidebar-stat-label{font-size:10px}.logout-btn{padding:10px;font-size:13px}.mobile-menu-toggle{display:none}.mobile-bottom-nav{position:fixed;left:max(10px,env(safe-area-inset-left));right:max(10px,env(safe-area-inset-right));bottom:max(10px,env(safe-area-inset-bottom));z-index:90;display:grid;grid-template-columns:repeat(auto-fit,minmax(56px,1fr));gap:6px;padding:7px;border:1px solid rgba(191,215,232,.82);border-radius:18px;background:#fffffff0;box-shadow:0 18px 48px #08172633;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.notification-trigger{width:42px;height:42px}.notification-panel{position:fixed;top:70px;right:12px;left:12px;width:auto;max-height:70vh}}@media (max-width: 480px){.sidebar{max-width:335px}.sidebar-header{padding:16px 12px}.sidebar-profile-card{margin:8px 6px 4px;padding:9px}.app-logo,.logo{gap:10px}.app-logo-mark{width:46px;height:46px}.app-logo-mark img{width:100%;height:100%}.app-logo-text{font-size:17px}.nav-menu{padding:10px 6px}.nav-item{padding:10px 12px;font-size:12px}.nav-icon{width:28px;height:28px;font-size:9px}.sidebar .nav-badge{font-size:10px;padding:0 6px;min-width:18px}.content-wrapper{padding:12px 10px 92px}.top-header{padding:max(10px,env(safe-area-inset-top)) 10px 10px}.header-title{width:100%}.header-title h1{font-size:15px;flex:1}.back-button{padding:.35rem .7rem;font-size:.85rem;min-height:38px}.top-header .header-actions{gap:8px}.language-switcher{padding:3px}.language-switcher button{min-width:30px;min-height:30px;font-size:11px}.quick-stats{gap:6px}.sidebar-footer .stat-item{padding:8px}.mobile-bottom-nav{left:max(8px,env(safe-area-inset-left));right:max(8px,env(safe-area-inset-right));bottom:max(8px,env(safe-area-inset-bottom));gap:4px;padding:6px;border-radius:16px}}@media (max-width: 768px) and (orientation: landscape){.sidebar{max-width:320px}.sidebar-header{padding:16px}.quick-stats{flex-direction:row}.top-header{padding:10px 14px}}@media (hover: none) and (pointer: coarse){.nav-item,.nav-child-item,.logout-btn{min-height:44px}.mobile-menu-toggle{min-width:44px;min-height:44px}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.sidebar ::-webkit-scrollbar-track{background:#ffffff0d}.sidebar ::-webkit-scrollbar-thumb{background:#fff3}.sidebar ::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.coming-soon{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:24px;color:var(--text-secondary);background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--surface-shadow)}@media (max-width: 768px){:root{--mobile-bottom-nav-height: calc(78px + env(safe-area-inset-bottom)) }body{background:#f3f7fb;overscroll-behavior-y:contain}button,input,select,textarea{font:inherit}button{touch-action:manipulation}input:not([type=checkbox]):not([type=radio]),select,textarea{min-height:48px;font-size:16px}.app-container,.main-content{min-height:var(--app-height)}.main-content{background:linear-gradient(180deg,#f8fbff,#f8fbff00 180px),#f3f7fb}.content-wrapper{padding:12px 12px calc(var(--mobile-bottom-nav-height) + 18px)}.top-header{gap:10px;padding:max(10px,env(safe-area-inset-top)) 12px 10px;min-height:60px}.header-title{flex:1 1 auto;flex-wrap:nowrap;min-width:0}.header-brand-mark{width:36px;height:36px;border-radius:10px}.header-title h1{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.back-button{min-width:40px;padding:0 10px;white-space:nowrap}.top-header .header-actions{gap:8px;margin-left:auto}.language-switcher{border-radius:10px}.language-switcher button{min-width:32px;min-height:32px}.notification-trigger{width:40px;height:40px;border-radius:11px}.notification-panel{top:calc(max(10px,env(safe-area-inset-top)) + 58px);left:10px;right:10px;max-height:calc(var(--app-height) - 88px);border-radius:14px}.notification-panel-body{max-height:calc(var(--app-height) - 176px)}.sidebar{width:min(92vw,360px);height:var(--app-height);padding-bottom:env(safe-area-inset-bottom);overscroll-behavior:contain}.mobile-overlay{background:#04101c8f;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.mobile-bottom-nav{left:0;right:0;bottom:0;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px;padding:7px 8px calc(7px + env(safe-area-inset-bottom));border-right:0;border-bottom:0;border-left:0;border-radius:18px 18px 0 0;background:#fffffff5}.mobile-bottom-nav-item{min-height:56px;border-radius:12px}.mobile-bottom-nav-icon{width:28px;height:24px;border-radius:7px}.mobile-bottom-nav-label{font-size:9.5px;white-space:normal;line-height:1.1}.modal-overlay{align-items:flex-end;padding:10px}.modal-content{max-height:calc(var(--app-height) - 20px);border-radius:18px 18px 0 0}}@media (max-width: 380px){.top-header{gap:6px}.header-brand-mark{width:34px;height:34px}.header-title h1{font-size:14px}.mobile-bottom-nav{padding-right:5px;padding-left:5px}.mobile-bottom-nav-label{font-size:9px}}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--app-height: 100vh}@supports (height: 100dvh){:root{--app-height: 100dvh}}html{min-height:100%;scrollbar-gutter:stable both-edges;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{margin:0;min-width:320px;min-height:var(--app-height);background:#f5f7fa;overflow-x:hidden;overflow-y:scroll}#root{width:100%;min-height:var(--app-height);overflow-x:clip}@media (max-width: 768px){html{scrollbar-gutter:auto}body{overflow-y:auto}}.app-root-error{min-height:var(--app-height);display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 20% 20%,#f0f5ff,#f7fbf5 45%,#eef2f7)}.app-root-error-card{width:min(720px,100%);background:#fff;border:1px solid #dbe3ec;border-radius:16px;box-shadow:0 16px 40px #1118271f;padding:28px;display:grid;gap:12px;text-align:center}.app-root-error-icon{width:46px;height:46px;margin:0 auto;border-radius:50%;background:#dc262624;color:#dc2626;font-size:26px;font-weight:800;display:inline-flex;align-items:center;justify-content:center}.app-root-error-card h1{margin:0;font-size:26px;color:#1f2937}.app-root-error-card p{margin:0;color:#4b5563;line-height:1.5}.app-root-error-detail{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;color:#6b7280;word-break:break-word}.app-root-error-reload{justify-self:center;border:none;border-radius:10px;padding:10px 16px;font-size:14px;font-weight:700;color:#fff;background:linear-gradient(135deg,#3b82f6,#1d4ed8);cursor:pointer}.app-root-error-reload:hover{filter:brightness(1.05)}
