*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh}.app{max-width:800px;margin:0 auto;padding:20px}.header{text-align:center;padding:24px 0;border-bottom:1px solid #1e293b;margin-bottom:32px}.header h1{font-size:24px;font-weight:700;color:#f1f5f9}.main{display:flex;flex-direction:column;align-items:center;gap:24px}.card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:32px;width:100%;max-width:480px}.card h2{font-size:18px;margin-bottom:16px;color:#f1f5f9}.card p{color:#94a3b8;margin-bottom:12px;line-height:1.6}.info{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:12px 16px;margin:12px 0;font-size:13px;color:#94a3b8;word-break:break-all}.info strong{color:#e2e8f0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none;width:100%}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.btn-success{background:#22c55e;color:#fff}.btn-success:hover{background:#16a34a}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-secondary{background:#334155;color:#e2e8f0}.btn-secondary:hover{background:#475569}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-group{display:flex;gap:8px;margin-top:16px}.btn-group .btn{flex:1}.request-list{width:100%;max-width:480px;display:flex;flex-direction:column;gap:12px}.request-card{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:20px}.request-card h3{font-size:15px;color:#f1f5f9;margin-bottom:4px}.request-card .meta{font-size:12px;color:#64748b;margin-bottom:12px}.badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600}.badge-pending{background:#f59e0b22;color:#fbbf24;border:1px solid #f59e0b44}.badge-approved{background:#22c55e22;color:#4ade80;border:1px solid #22c55e44}.badge-denied{background:#ef444422;color:#f87171;border:1px solid #ef444444}.empty-state{text-align:center;padding:32px 16px;color:#64748b}.empty-state p{font-size:14px}.spinner{width:32px;height:32px;border:3px solid #334155;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin:20px auto}@keyframes spin{to{transform:rotate(360deg)}}.status-icon{font-size:40px;margin-bottom:12px}.success-text{color:#4ade80}.warning-text{color:#fbbf24}.error-text{color:#f87171}
