:root{--primary-font: "Poppins", system-ui, -apple-system, sans-serif;--primary-color: #2d348a;--primary-light: #4c51bf;--accent-color: #03a680;--bg-gradient: linear-gradient(135deg, #f8faff 0%, #eff6ff 100%);--card-bg: #ffffff;--text-main: #1e293b;--text-muted: #64748b;--border-color: rgba(226, 232, 240, .8);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius-lg: 16px;--radius-xl: 24px;--white: #fff;--transition: all .2s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;font-family:var(--primary-font);background:var(--bg-gradient);color:var(--text-main);line-height:1.5}a{color:var(--primary-light);text-decoration:none;transition:var(--transition)}a:hover{color:var(--primary-color)}.center-screen{min-height:100vh;display:flex;align-items:center;justify-content:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}.animate-fade{animation:fadeIn .4s ease-out forwards}.login-page{min-height:100vh;padding:24px;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top right,rgba(76,81,191,.05),transparent),radial-gradient(circle at bottom left,rgba(3,166,128,.05),transparent)}.login-card{width:min(1000px,100%);background:var(--card-bg);border-radius:var(--radius-xl);display:grid;grid-template-columns:1.1fr .9fr;overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);animation:fadeIn .6s ease-out}.login-left{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);color:var(--white);padding:60px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;top:-20%;right:-20%;width:300px;height:300px;background:#ffffff0d;border-radius:50%}.login-left h1{margin:16px 0;font-size:40px;font-weight:800;line-height:1.1;letter-spacing:-.02em}.login-left p{color:#ffffffd9;font-size:17px;max-width:340px;line-height:1.6}.login-pill{width:fit-content;margin-bottom:24px;background:#ffffff1a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2);border-radius:99px;padding:6px 16px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.login-right{padding:60px;display:flex;flex-direction:column;justify-content:center;gap:24px}.login-right h2{margin:0;color:var(--text-main);font-size:32px;font-weight:700}.role-toggle{background:#f1f5f9;padding:4px;border-radius:12px;display:grid;grid-template-columns:1fr 1fr;gap:4px}.role-toggle button{border:0;padding:10px;font-size:14px;font-weight:600;border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;transition:var(--transition)}.role-toggle button.active{background:var(--white);color:var(--primary-color);box-shadow:var(--shadow-sm)}button{border:0;padding:12px 20px;font-size:15px;font-weight:600;border-radius:10px;background:var(--primary-color);color:var(--white);cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:8px}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md);filter:brightness(1.1)}button:active:not(:disabled){transform:translateY(0)}button.secondary{background:#f1f5f9;color:var(--text-main)}button.secondary:hover{background:#e2e8f0}button.danger{background:#ef4444}label{display:flex;flex-direction:column;gap:8px;color:var(--text-main);font-weight:600;font-size:14px}input,select,textarea{border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px;font-size:15px;font-family:inherit;background:#f8fafc;transition:var(--transition);width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-light);background:var(--white);box-shadow:0 0 0 3px #4c51bf1a}.submit-btn{margin-top:8px;padding:14px;font-size:16px;font-weight:700;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%)}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.error-text{margin:0;color:#ef4444;font-size:13px;padding:10px 14px;background:#fef2f2;border-radius:8px;border:1px solid #fee2e2}.form-error-text{margin:0;color:#b91c1c;font-size:13px;font-weight:500}.toast-stack{position:fixed;right:24px;bottom:24px;display:grid;gap:10px;z-index:1100}.toast-item{min-width:260px;max-width:420px;border-radius:12px;padding:11px 14px;font-size:14px;font-weight:600;box-shadow:var(--shadow-lg);border:1px solid;animation:fadeIn .2s ease-out forwards}.toast-success{background:#ecfdf3;color:#166534;border-color:#86efac}.toast-error{background:#fef2f2;color:#991b1b;border-color:#fca5a5}.toast-info{background:#eff6ff;color:#1d4ed8;border-color:#93c5fd}.app-modal-backdrop{position:fixed;inset:0;z-index:1200;background:#02061780;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;padding:20px}.app-modal{width:min(100%,560px);background:#fff;border-radius:18px;border:1px solid #e2e8f0;box-shadow:var(--shadow-lg);overflow:hidden;animation:fadeIn .2s ease-out forwards}.app-modal-head{padding:20px 22px 14px}.app-modal-head h3{margin:0;font-size:20px;line-height:1.2}.app-modal-head p{margin:8px 0 0;color:var(--text-muted);font-size:14px}.app-modal-body{display:grid;gap:14px;padding:0 22px 18px}.app-modal-footer{padding:14px 22px 20px;display:flex;justify-content:flex-end;gap:10px;border-top:1px solid #f1f5f9}.app-shell{min-height:100vh;display:grid;grid-template-columns:280px 1fr}.sidebar{background:var(--white);border-right:1px solid var(--border-color);padding:24px 16px;display:flex;flex-direction:column;gap:32px;height:100vh;position:sticky;top:0}.sidebar-brand{padding:0 8px;display:flex;align-items:center;gap:12px}.sidebar-brand-badge{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);color:var(--white);font-weight:800;font-size:18px;box-shadow:var(--shadow-md)}.sidebar-brand-info{display:flex;flex-direction:column}.sidebar-brand-title{margin:0;font-size:14px;color:var(--text-main);font-weight:800;letter-spacing:-.01em}.sidebar-brand-subtitle{margin:0;font-size:11px;color:var(--accent-color);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.sidebar-nav{display:flex;flex-direction:column;gap:4px;flex:1}.nav-item{text-decoration:none;color:var(--text-muted);border-radius:10px;display:flex;align-items:center;gap:12px;padding:12px 14px;font-weight:600;font-size:14px;transition:var(--transition)}.nav-item:hover{background:#f1f5f9;color:var(--text-main)}.nav-item-active{background:#2d348a14;color:var(--primary-color)}.sidebar-footer{margin-top:auto;padding-top:24px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:16px}.user-info{padding:0 8px}.sidebar-user-role{margin:0;color:var(--text-main);font-size:13px;font-weight:700}.sidebar-user-email{margin:2px 0 0;color:var(--text-muted);font-size:12px}.logout-btn{width:100%;background:#f8fafc;color:var(--text-main);border:1px solid #e2e8f0}.logout-btn:hover{background:#f1f5f9;color:#ef4444;border-color:#fee2e2}.content-area{padding:32px;max-width:1400px;margin:0 auto;width:100%}.content-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.content-header h1{margin:0;font-size:28px;font-weight:800;color:var(--text-main);letter-spacing:-.02em}.content-body{animation:fadeIn .4s ease-out}.module-grid{display:grid;gap:24px;grid-template-columns:repeat(2,minmax(0,1fr))}.module-grid-1{grid-template-columns:1fr}.module-card{background:var(--white);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);transition:var(--transition)}.module-card:hover{box-shadow:var(--shadow-md)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.card-head h3{margin:0;font-size:18px;font-weight:700;color:var(--text-main)}.metric-card{display:flex;flex-direction:column}.metric-label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.metric-value{font-size:32px;font-weight:800;color:var(--text-main);line-height:1}.muted{margin:8px 0 0;color:var(--text-muted);font-size:13px}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.card-actions{display:flex;gap:10px}.table-wrap{background:var(--white);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;margin-top:16px}table{width:100%;border-collapse:collapse}th{background:#f8fafc;color:var(--text-muted);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.05em;padding:14px 20px;border-bottom:1px solid var(--border-color);text-align:left}td{padding:16px 20px;border-bottom:1px solid var(--border-color);color:var(--text-main);font-size:14px;vertical-align:middle}tr:last-child td{border-bottom:0}tr:hover td{background:#fcfdfe}.btn-row{display:flex;flex-wrap:wrap;gap:12px}.row-item{display:flex;justify-content:space-between;align-items:center;gap:16px;border:1px solid var(--border-color);border-radius:12px;padding:14px 16px;transition:var(--transition)}.row-item:hover{border-color:var(--primary-light);background:#f8faff}.pill{display:inline-flex;align-items:center;justify-content:center;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.02em}.pill.ok{background:#dcfce7;color:#166534}.pill.warn{background:#fef9c3;color:#854d0e}.pill.bad{background:#fee2e2;color:#991b1b}@media(max-width:1024px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.login-card{grid-template-columns:1fr;max-width:500px}.login-left{display:none}}@media(max-width:768px){.content-area{padding:20px}.module-grid{grid-template-columns:1fr}.content-header{flex-direction:column;align-items:flex-start;gap:16px}}
