@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary:#f5f7fa;--bg-secondary:#fff;--bg-card:#fff;--bg-glass:#3741510a;--border-color:#e2e8f0;--border-active:#37415166;--text-primary:#1e293b;--text-secondary:#475569;--text-muted:#94a3b8;--accent:#0f2b52;--accent-hover:#0a1f3d;--accent-light:#f0f4ff;--accent-glow:#0f2b5226;--sidebar-bg:#0f2b52;--sidebar-text:#cbd5e1;--sidebar-active:#ffffff26;--header-bg:#fff;--success:#059669;--warning:#d97706;--danger:#dc2626;--info:#6b7280;--sidebar-width:260px;--header-height:64px;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #00000014, 0 4px 16px #0000000a;--shadow-lg:0 4px 24px #0000001a;--transition:all .2s ease}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.loading-screen{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-page{background:linear-gradient(135deg,#0b1329 0%,#0f2b52 50%,#1e3a8a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle,#60a5fa1f,#0000 70%);width:600px;height:600px;animation:8s ease-in-out infinite float;position:absolute;top:-150px;right:-150px}.login-page:after{content:"";background:radial-gradient(circle,#60a5fa14,#0000 70%);width:400px;height:400px;animation:6s ease-in-out infinite reverse float;position:absolute;bottom:-100px;left:-100px}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(30px,-30px)}}.login-card{-webkit-backdrop-filter:blur(16px)saturate(120%);z-index:1;background:#0b132bbf;border:1px solid #ffffff14;border-radius:20px;width:100%;max-width:420px;padding:48px;animation:.5s slideUp;position:relative;box-shadow:0 24px 60px #0006,inset 0 1px #ffffff1a}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card h1{text-align:center;color:#fff;text-shadow:0 2px 10px #ffffff0d;margin-bottom:4px;font-size:1.5rem;font-weight:700}.login-card .subtitle{text-align:center;color:#94a3b8;margin-bottom:32px;font-size:.85rem}.login-card .logo-icon{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 16px;display:flex;overflow:hidden}.login-card .logo-icon img{object-fit:contain;width:100%;height:100%;padding:4px}.login-card .form-group label{color:#cbd5e1}.login-card .form-input{color:#fff;background:#0f172a80;border:1px solid #ffffff1a}.login-card .form-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa40}.login-card .form-input::placeholder{color:#64748b}.login-card select.form-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.login-card .toggle-pw{color:#64748b}.login-card .toggle-pw:hover{color:#cbd5e1}.login-card .btn-primary{background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);border:none;box-shadow:0 4px 14px #2563eb4d}.login-card .btn-primary:hover{background:linear-gradient(135deg,#4f46e5 0%,#2563eb 100%);transform:translateY(-1px);box-shadow:0 6px 20px #2563eb66}.login-link{color:#60a5fa;transition:var(--transition);font-size:.85rem}.login-link:hover{color:#93c5fd;text-decoration:underline}.login-alert{border-radius:8px;margin-bottom:20px;padding:10px 14px;font-size:.85rem}.login-alert-error{color:#fca5a5;background:#ef444426;border:1px solid #ef44444d}.login-alert-success{color:#6ee7b7;background:#10b98126;border:1px solid #10b9814d}.form-group{margin-bottom:20px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:.85rem;font-weight:500;display:block}.form-input{border:1.5px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:var(--transition);background:#fff;outline:none;padding:11px 14px;font-family:inherit;font-size:.9rem}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--text-muted)}.input-wrapper{position:relative}.input-wrapper .toggle-pw{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.input-wrapper .toggle-pw:hover{color:var(--text-secondary)}select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}textarea.form-input{resize:vertical;min-height:80px}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:.9rem;font-weight:500;display:inline-flex}.btn svg{width:18px;height:18px}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#047857}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-warning{background:var(--warning);color:#fff}.btn-ghost{color:var(--text-secondary);border:1.5px solid var(--border-color);background:0 0}.btn-ghost:hover{background:var(--bg-glass);color:var(--text-primary);border-color:var(--accent)}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-full{justify-content:center;width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);z-index:100;background:#0b1329;border-right:1px solid #ffffff0d;flex-direction:column;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:4px 0 24px #00000026}.sidebar-header{border-bottom:1px solid #ffffff0f;align-items:center;gap:12px;padding:24px 20px;display:flex}.sidebar-header .logo{background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.sidebar-header .logo img{object-fit:contain;width:100%;height:100%}.sidebar-header .app-name{color:#fff;letter-spacing:-.01em;font-size:.95rem;font-weight:700}.sidebar-header .app-name span{color:#ffffff80;margin-top:1px;font-size:.72rem;font-weight:400;display:block}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section{margin-bottom:28px}.nav-section-title{text-transform:uppercase;letter-spacing:1.2px;color:#ffffff59;margin-bottom:10px;padding:0 12px;font-size:.65rem;font-weight:700}.nav-link{border-radius:var(--radius-sm);color:#ffffffa6;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;margin-bottom:4px;padding:10px 12px;font-family:inherit;font-size:.88rem;transition:all .2s;display:flex}.nav-link:hover{color:#fff;background:#ffffff0a;padding-left:14px}.nav-link.active{color:#60a5fa;background:#3b82f626;border-left:3px solid #3b82f6;border-top-left-radius:0;border-bottom-left-radius:0;padding-left:9px;font-weight:600}.nav-link svg{opacity:.85;flex-shrink:0;width:18px;height:18px}.nav-link.active svg{color:#60a5fa;opacity:1}.sidebar-footer{background:#00000026;border-top:1px solid #ffffff0f;padding:16px 12px}.user-info{border-radius:var(--radius-sm);background:#ffffff08;border:1px solid #ffffff0a;align-items:center;gap:12px;padding:10px;display:flex}.user-avatar{color:#fff;background:#1e40af;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:600;display:flex;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%;display:block}.user-details{flex:1;min-width:0}.user-details .name{white-space:nowrap;text-overflow:ellipsis;color:#fff;font-size:.85rem;font-weight:500;overflow:hidden}.user-details .role{color:#ffffff80;text-transform:capitalize;font-size:.75rem}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.header{height:var(--header-height);background:var(--header-bg);border-bottom:1px solid var(--border-color);z-index:50;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 1px 3px #0000000d}.header-left{align-items:center;gap:16px;display:flex}.header-left h2{color:var(--text-primary);margin:0;font-size:1.15rem;font-weight:600}.menu-toggle{color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:4px;display:none}.header-right{justify-content:flex-end;align-items:center;gap:12px;display:flex}.notif-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:var(--transition);background:#f1f5f9;justify-content:center;align-items:center;padding:8px;display:flex;position:relative}.notif-btn:hover{color:var(--text-primary);background:#e2e8f0}.notif-badge{background:var(--danger);color:#fff;border:2px solid var(--header-bg);border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;font-weight:700;animation:2s infinite pulse-badge;display:flex;position:absolute;top:-4px;right:-4px}@keyframes pulse-badge{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.notif-popup{border:1px solid var(--border-color);border-radius:var(--radius);width:360px;max-height:400px;box-shadow:var(--shadow-lg);z-index:200;background:#fff;animation:.2s slideDown;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notif-popup-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px;display:flex}.notif-popup-header h3{color:var(--text-primary);font-size:.95rem}.notif-popup-list{max-height:320px;overflow-y:auto}.notif-popup-list::-webkit-scrollbar{width:8px}.notif-popup-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.notif-popup-list::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:4px;min-height:40px}.notif-popup-list::-webkit-scrollbar-thumb:hover{background:#64748b}.notif-item{border-bottom:1px solid var(--border-color);cursor:pointer;transition:var(--transition);padding:12px 16px}.notif-item:hover{background:var(--accent-light)}.notif-item.unread{border-left:3px solid var(--accent);background:#f9fafb}.notif-item .notif-title{color:var(--text-primary);margin-bottom:2px;font-size:.85rem;font-weight:500}.notif-item .notif-msg{color:var(--text-secondary);font-size:.8rem}.notif-item .notif-time{color:var(--text-muted);margin-top:4px;font-size:.7rem}.notif-empty{text-align:center;color:var(--text-muted);padding:32px;font-size:.85rem}mark,.search-highlight{color:#92400e;background:linear-gradient(135deg,#fde68a,#fbbf24);border-radius:3px;padding:1px 3px;font-weight:600;box-shadow:0 1px 2px #fbbf244d}.header-clock{color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);white-space:nowrap;font-variant-numeric:tabular-nums;background:#f1f5f9;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;display:flex}.header-clock svg{opacity:.8;flex-shrink:0}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:.75rem;font-weight:600}.detail-value{color:var(--text-primary);word-break:break-word;font-size:.95rem}.page{flex:1;padding:24px;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.page-header h1{color:var(--text-primary);font-size:1.5rem;font-weight:700}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);transition:var(--transition);box-shadow:var(--shadow);padding:24px}.card:hover{box-shadow:var(--shadow-lg)}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow);justify-content:space-between;align-items:center;padding:22px 24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.stat-card:hover{transform:translateY(-5px)}.stat-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:54px;height:54px;display:flex;box-shadow:inset 0 2px 4px #00000005}.stat-icon.blue{color:#2563eb;background:#eff6ff}.stat-icon.green{color:#16a34a;background:#f0fdf4}.stat-icon.yellow{color:#d97706;background:#fffbeb}.stat-icon.red{color:#dc2626;background:#fef2f2}.stat-icon.purple{color:#7c3aed;background:#f5f3ff}.stat-value{color:var(--text-primary);font-size:2.1rem;font-weight:800;line-height:1.1}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;font-weight:600}.stat-desc{color:var(--text-muted);margin-top:2px;font-size:.72rem}.welcome-banner{color:#fff;border-radius:var(--radius);background:#0f2b52;margin-bottom:24px;padding:28px;box-shadow:0 10px 25px -5px #0f2b5233,0 8px 10px -6px #0f2b5233}.welcome-title{color:#fff;letter-spacing:-.02em;margin-bottom:6px;font-size:1.75rem;font-weight:700}.welcome-desc{color:#ffffffd9;max-width:100%;font-size:.92rem;font-weight:400;line-height:1.5}.clickable-row{cursor:pointer;transition:background-color .15s}.clickable-row:hover td{background-color:#f8fafc!important}.surat-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.surat-card{border:1px solid var(--border-color);border-radius:var(--radius);transition:var(--transition);box-shadow:var(--shadow);background:#fff;flex-direction:column;gap:12px;padding:20px;display:flex}.surat-card:hover{border-color:var(--border-active);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.surat-card-header{justify-content:space-between;align-items:flex-start;display:flex}.surat-card-header .no-surat{color:var(--text-primary);font-size:.95rem;font-weight:600}.surat-card .perihal{color:var(--text-secondary);font-size:.85rem}.surat-card .meta{color:var(--text-muted);gap:16px;font-size:.8rem;display:flex}.surat-card .actions{gap:8px;margin-top:auto;display:flex}.badge{border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-menunggu{color:#92400e;background:#fef3c7}.badge-disetujui{color:#065f46;background:#d1fae5}.badge-ditolak{color:#991b1b;background:#fee2e2}.badge-diteruskan{color:#374151;background:#f3f4f6}.badge-diarsipkan{color:#64748b;background:#f1f5f9}.table-container{border-radius:var(--radius);border:1px solid var(--border-color);box-shadow:var(--shadow);overflow-x:auto}table{border-collapse:collapse;background:#fff;width:100%}th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background:#f8fafc;padding:12px 16px;font-size:.8rem;font-weight:600}td{border-top:1px solid var(--border-color);color:var(--text-primary);padding:12px 16px;font-size:.9rem}tr:hover td{background:#f8fafc}.table-actions{gap:6px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--border-color);border-radius:var(--radius);background:#fff;width:100%;max-width:520px;max-height:90vh;animation:.3s slideUp;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{color:var(--text-primary);font-size:1.1rem;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;display:flex}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.toast-container{z-index:2000;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{border-radius:var(--radius-sm);color:#fff;min-width:280px;box-shadow:var(--shadow-lg);align-items:center;gap:8px;padding:12px 20px;font-size:.85rem;animation:.3s slideIn;display:flex}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-info{background:var(--info)}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.profile-card{align-items:center;gap:24px;margin-bottom:24px;display:flex}.profile-avatar{color:#fff;background:linear-gradient(135deg,#4b5563,#6b7280);border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;font-size:2rem;font-weight:700;display:flex;overflow:hidden}.profile-avatar img{object-fit:cover;border-radius:20px;width:100%;height:100%}.filters{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.filter-btn{border:1.5px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border-radius:20px;padding:6px 16px;font-family:inherit;font-size:.8rem}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.file-upload{border:2px dashed var(--border-color);border-radius:var(--radius);text-align:center;cursor:pointer;transition:var(--transition);color:var(--text-muted);padding:32px}.file-upload:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.file-upload input{display:none}.file-upload svg{margin-bottom:8px}.empty-state{text-align:center;color:var(--text-muted);padding:48px 24px}.empty-state svg{opacity:.4;margin-bottom:16px}.empty-state h3{color:var(--text-secondary);margin-bottom:8px}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.menu-toggle{display:flex}.page{padding:16px}.stat-grid{grid-template-columns:repeat(2,1fr)}.surat-grid{grid-template-columns:1fr}.notif-popup{width:calc(100vw - 32px);right:-60px}.header-clock{display:none}.page-header{flex-direction:column;align-items:flex-start}.login-card{margin:16px;padding:32px 24px}.profile-card{text-align:center;flex-direction:column}.modal{max-width:calc(100vw - 32px);margin:16px}}.sidebar-overlay{z-index:99;background:#00000080;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar.open~.sidebar-overlay{display:block}}
