@import "https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap";:root{--font-primary:"Poppins", sans-serif;--color-primary-dark:#111d29;--color-accent-blue:#5566fa;--color-accent-orange:#ff622a;--color-accent-blue-light:#e8ebff;--color-bg-page:#eff1f4;--color-bg-card:#ffffffd9;--color-border:#d0d3d7;--color-border-hover:#9fa4a9;--color-text-main:#111d29;--color-text-muted:#54595f;--color-white:#fff;--color-overlay:#111d2966;--color-success:#114e0b;--color-success-bg:#cef5ca;--color-success-border:#a3e49b;--color-error:#3b0b0b;--color-error-bg:#f8e4e4;--color-error-border:#f1b5b5;--color-info-bg:#e8ebff;--color-info-border:#c8ceff;--color-info-text:#1e2d9e;--card-shadow:0 12px 36px -12px #111d291f, 0 4px 12px -4px #111d290a;--border-radius-sm:6px;--border-radius-md:12px;--border-radius-lg:20px;--transition-fast:all .15s ease;--transition-normal:all .3s cubic-bezier(.4, 0, .2, 1);--backdrop-blur:blur(12px)}.glass-effect{background:var(--color-bg-card);-webkit-backdrop-filter:var(--backdrop-blur);box-shadow:var(--card-shadow);border:1px solid #ffffff80}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-primary);background-color:var(--color-bg-page);background-image:radial-gradient(at 0% 0%, var(--color-accent-blue-light) 0px, transparent 50%), radial-gradient(at 100% 100%, var(--color-bg-page) 0px, transparent 50%);color:var(--color-text-main);flex-direction:column;min-height:100vh;font-size:16px;line-height:1.6;display:flex}#root{flex-direction:column;flex:1;min-height:100vh;display:flex}a{color:var(--color-accent-blue);transition:var(--transition-fast);text-decoration:none}a:hover{opacity:.8}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.form-group{text-align:left;margin-bottom:20px}label{color:var(--color-text-muted);margin-bottom:6px;font-size:14px;font-weight:500;display:block}input,select,textarea{width:100%;font-family:var(--font-primary);color:var(--color-text-main);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);transition:var(--transition-fast);background-color:#ffffffb3;outline:none;padding:12px 16px;font-size:15px}input:focus,select:focus,textarea:focus{border-color:var(--color-accent-blue);background-color:var(--color-white);box-shadow:0 0 0 3px #5566fa26}input:disabled,select:disabled,textarea:disabled{color:var(--color-text-muted);cursor:not-allowed;background-color:#111d290a}.btn{font-family:var(--font-primary);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-normal);border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:500;text-decoration:none;display:inline-flex}.btn-primary{background-color:var(--color-accent-blue);color:var(--color-white)}.btn-primary:hover{background-color:#3b4eff;transform:translateY(-2px);box-shadow:0 4px 12px #5566fa4d}.btn-secondary{background-color:var(--color-accent-blue-light);color:var(--color-accent-blue)}.btn-secondary:hover{background-color:#dbe0ff;transform:translateY(-2px)}.btn-danger{background-color:var(--color-error-bg);color:#c02424;border:1px solid var(--color-error-border)}.btn-danger:hover{background-color:#f7d2d2;transform:translateY(-2px)}.btn-orange{background-color:var(--color-accent-orange);color:var(--color-white)}.btn-orange:hover{background-color:#e54c15;transform:translateY(-2px);box-shadow:0 4px 12px #ff622a4d}.btn:active{transform:translateY(0)}.auth-wrapper{flex:1;justify-content:center;align-items:center;padding:40px 20px;display:flex}.auth-card{border-radius:var(--border-radius-lg);text-align:center;width:100%;max-width:460px;padding:40px;animation:.6s cubic-bezier(.16,1,.3,1) slideUp}.auth-logo{justify-content:center;margin-bottom:24px;display:flex}.auth-logo svg{color:var(--color-primary-dark);width:auto;height:48px}.auth-card h2{margin-bottom:8px;font-size:26px;font-weight:700}.auth-card p{color:var(--color-text-muted);margin-bottom:30px;font-size:14px}.auth-switch{color:var(--color-text-muted);margin-top:24px;font-size:14px}.header{-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);color:var(--color-white);z-index:100;background:#111d29f2;border-bottom:1px solid #ffffff1a;padding:15px 0;position:sticky;top:0}.header-container{justify-content:space-between;align-items:center;display:flex}.header-logo{align-items:center;display:flex}.header-logo svg{color:var(--color-white);width:auto;height:36px;margin-right:12px}.header-logo span{letter-spacing:.5px;font-size:18px;font-weight:600}.header-actions{align-items:center;gap:16px;display:flex}.user-badge{background:#ffffff1a;border-radius:50px;align-items:center;gap:8px;padding:6px 14px;font-size:14px;display:flex}.user-badge .role-tag{text-transform:uppercase;background-color:var(--color-accent-orange);border-radius:50px;padding:2px 8px;font-size:10px;font-weight:700}.user-badge .role-tag.admin{background-color:var(--color-accent-blue)}.logout-btn{color:#ffffffb3;font-family:var(--font-primary);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;font-size:14px}.logout-btn:hover{color:var(--color-accent-orange)}.dashboard-layout{flex:1;grid-template-columns:280px 1fr;display:grid}.sidebar{border-right:1px solid var(--color-border);background:#111d2905;padding:30px 20px}.sidebar-menu{flex-direction:column;gap:8px;list-style:none;display:flex}.sidebar-link{color:var(--color-text-muted);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-normal);text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 16px;font-weight:500;display:flex}.sidebar-link:hover,.sidebar-link.active{background-color:var(--color-accent-blue-light);color:var(--color-accent-blue)}.main-content{padding:40px;overflow-y:auto}.page-title-block{margin-bottom:30px}.page-title-block h1{color:var(--color-primary-dark);font-size:28px;font-weight:700}.page-title-block p{color:var(--color-text-muted);font-size:15px}.card{border-radius:var(--border-radius-md);border:1px solid #fff6;margin-bottom:30px;padding:30px}.card-title{color:var(--color-primary-dark);justify-content:space-between;align-items:center;margin-bottom:20px;font-size:18px;font-weight:600;display:flex}.table-responsive{width:100%;overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table th{color:var(--color-text-muted);border-bottom:2px solid var(--color-border);padding:16px 20px;font-size:14px;font-weight:600}.data-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:16px 20px;font-size:15px}.data-table tr{transition:var(--transition-fast)}.data-table tr:hover{background-color:#5566fa08}.action-link{cursor:pointer;color:var(--color-accent-blue);font-size:14px;font-weight:500;font-family:var(--font-primary);background:0 0;border:none;align-items:center;gap:6px;display:inline-flex}.action-link.delete{color:#c02424}.alert{border-radius:var(--border-radius-sm);border:1px solid #0000;align-items:center;gap:12px;margin-bottom:20px;padding:14px 20px;font-size:14px;animation:.3s fadeIn;display:flex}.alert-success{background-color:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success)}.alert-error{background-color:var(--color-error-bg);border-color:var(--color-error-border);color:var(--color-error)}.alert-info{background-color:var(--color-info-bg);border-color:var(--color-info-border);color:var(--color-info-text)}.modal-overlay{background-color:var(--color-overlay);-webkit-backdrop-filter:blur(8px);z-index:1000;opacity:0;pointer-events:none;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:all}.modal-content{border-radius:var(--border-radius-lg);width:100%;max-width:650px;max-height:90vh;padding:40px;transition:transform .3s cubic-bezier(.16,1,.3,1);position:relative;overflow-y:auto;transform:scale(.9)}.modal-overlay.open .modal-content{transform:scale(1)}.modal-close{cursor:pointer;color:var(--color-text-muted);transition:var(--transition-fast);background:0 0;border:none;font-size:24px;position:absolute;top:24px;right:24px}.modal-close:hover{color:var(--color-primary-dark)}.upload-dropzone{border:2px dashed var(--color-border);border-radius:var(--border-radius-md);text-align:center;cursor:pointer;transition:var(--transition-normal);background-color:#fff6;flex-direction:column;align-items:center;gap:12px;padding:30px;display:flex}.upload-dropzone:hover,.upload-dropzone.dragover{border-color:var(--color-accent-blue);background-color:#5566fa0d}.upload-dropzone svg{color:var(--color-accent-blue);width:auto;height:48px}.upload-dropzone span{color:var(--color-text-muted);font-size:14px}.upload-dropzone input[type=file]{display:none}@media (width<=991px){.dashboard-layout{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--color-border);padding:20px}.sidebar-menu{white-space:nowrap;flex-direction:row;padding-bottom:10px;overflow-x:auto}.main-content{padding:20px}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
