@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap');

:root {
    --primary: #0d9488;
    --primary-dark: #0f766e;
    --primary-light: #5eead4;
    --accent: #f59e0b;
    --success: #22c55e;
    --warning: #eab308;
    --danger: #ef4444;
    --info: #3b82f6;
    --bg: #f0fdf4;
    --bg-white: #ffffff;
    --bg-card: #ffffff;
    --text-dark: #0f172a;
    --text-mid: #475569;
    --text-light: #94a3b8;
    --border: #e2e8f0;
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
    --shadow-md: 0 4px 20px rgba(0,0,0,0.08);
    --shadow-lg: 0 10px 40px rgba(0,0,0,0.1);
    --radius: 14px;
    --radius-sm: 8px;
}

* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:'Plus Jakarta Sans',sans-serif; background:var(--bg); color:var(--text-dark); min-height:100vh; }

/* ===== LOGIN ===== */
.login-page {
    min-height:100vh;
    display:grid;
    grid-template-columns:1fr 1fr;
}

.login-banner {
    background: linear-gradient(160deg, #0d9488 0%, #065f46 50%, #064e3b 100%);
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    padding:60px;
    position:relative;
    overflow:hidden;
}

.login-banner::before {
    content:'';
    position:absolute;
    width:500px;height:500px;
    border-radius:50%;
    background:rgba(255,255,255,0.05);
    top:-100px;right:-100px;
}

.login-banner::after {
    content:'';
    position:absolute;
    width:300px;height:300px;
    border-radius:50%;
    background:rgba(255,255,255,0.03);
    bottom:-50px;left:-50px;
}

.login-banner .banner-content { position:relative; z-index:2; text-align:center; color:white; }
.login-banner .hospital-icon { font-size:72px; margin-bottom:24px; filter:drop-shadow(0 4px 12px rgba(0,0,0,0.2)); }
.login-banner h1 { font-size:32px; font-weight:800; margin-bottom:12px; }
.login-banner p { font-size:16px; opacity:0.85; max-width:340px; line-height:1.6; }

.login-banner .features-list {
    margin-top:36px;
    text-align:left;
    list-style:none;
}

.login-banner .features-list li {
    padding:8px 0;
    font-size:14px;
    opacity:0.9;
    display:flex;
    align-items:center;
    gap:10px;
}

.login-banner .features-list li::before { content:'✓'; background:#22c55e; color:white; width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; flex-shrink:0; }

.login-form-section {
    display:flex;
    align-items:center;
    justify-content:center;
    padding:40px;
    background:var(--bg-white);
}

.login-form-box { width:100%; max-width:400px; }
.login-form-box .brand-sm { display:flex; align-items:center; gap:12px; margin-bottom:36px; }
.login-form-box .brand-sm .dot { width:40px;height:40px;border-radius:10px;background:var(--primary);display:flex;align-items:center;justify-content:center;color:white;font-size:18px;font-weight:800; }
.login-form-box .brand-sm span { font-weight:700; font-size:16px; color:var(--text-dark); }
.login-form-box h2 { font-size:26px; font-weight:800; margin-bottom:6px; }
.login-form-box .sub { color:var(--text-light); font-size:14px; margin-bottom:28px; }

.form-group { margin-bottom:18px; }
.form-group label { display:block; font-size:13px; font-weight:600; color:var(--text-mid); margin-bottom:6px; }

.form-input {
    width:100%;
    padding:12px 14px;
    border-radius:var(--radius-sm);
    border:1.5px solid var(--border);
    font-family:inherit;
    font-size:14px;
    color:var(--text-dark);
    background:var(--bg);
    transition:all 0.2s;
    outline:none;
}

.form-input:focus { border-color:var(--primary); box-shadow:0 0 0 3px rgba(13,148,136,0.12); background:white; }
select.form-input { cursor:pointer; 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 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; }

.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 24px; border-radius:var(--radius-sm); border:none; font-family:inherit; font-size:14px; font-weight:600; cursor:pointer; transition:all 0.2s; text-decoration:none; }
.btn-primary { background:var(--primary); color:white; width:100%; padding:13px; font-size:15px; }
.btn-primary:hover { background:var(--primary-dark); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-success { background:var(--success); color:white; }
.btn-success:hover { background:#16a34a; }
.btn-danger { background:var(--danger); color:white; }
.btn-danger:hover { background:#dc2626; }
.btn-warning { background:var(--accent); color:white; }
.btn-outline { background:transparent; color:var(--text-mid); border:1.5px solid var(--border); }
.btn-outline:hover { border-color:var(--primary); color:var(--primary); }
.btn-sm { padding:8px 14px; font-size:13px; }
.btn-icon { width:36px;height:36px;padding:0;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center; }

.demo-box { margin-top:24px; padding:16px; background:var(--bg); border-radius:var(--radius-sm); border:1px dashed var(--border); }
.demo-box p { font-size:13px; color:var(--text-light); }
.demo-box code { background:rgba(13,148,136,0.1); color:var(--primary); padding:2px 6px; border-radius:4px; font-size:13px; }

.alert { padding:12px 16px; border-radius:var(--radius-sm); margin-bottom:16px; font-size:14px; display:flex; align-items:center; gap:8px; }
.alert-danger { background:#fef2f2; border:1px solid #fecaca; color:#dc2626; }
.alert-success { background:#f0fdf4; border:1px solid #bbf7d0; color:#16a34a; }

/* ===== LAYOUT ===== */
.app-layout { display:flex; min-height:100vh; }

.sidebar {
    width:250px;
    background:white;
    border-right:1px solid var(--border);
    padding:20px 0;
    display:flex;
    flex-direction:column;
    position:fixed;
    top:0;left:0;bottom:0;
    z-index:100;
    transition:transform 0.3s;
}

.sidebar-brand { padding:0 20px 20px; border-bottom:1px solid var(--border); }
.sidebar-brand .logo-wrap { display:flex; align-items:center; gap:10px; }
.sidebar-brand .logo-icon { width:38px;height:38px;border-radius:10px;background:var(--primary);display:flex;align-items:center;justify-content:center;color:white;font-weight:800;font-size:16px; }
.sidebar-brand h3 { font-size:15px; font-weight:700; color:var(--text-dark); }
.sidebar-brand small { font-size:11px; color:var(--text-light); }

.sidebar-nav { flex:1; padding:12px 10px; }
.nav-item { display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius:var(--radius-sm); color:var(--text-mid); text-decoration:none; font-size:14px; font-weight:500; margin-bottom:2px; transition:all 0.2s; }
.nav-item:hover { background:var(--bg); color:var(--primary); }
.nav-item.active { background:rgba(13,148,136,0.08); color:var(--primary); font-weight:600; }
.nav-item i { width:18px; text-align:center; font-size:15px; }

.sidebar-footer { padding:12px 10px 0; border-top:1px solid var(--border); margin-top:auto; }

.main-content { flex:1; margin-left:250px; padding:24px; }

.topbar { display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; flex-wrap:wrap; gap:12px; }
.topbar h1 { font-size:22px; font-weight:700; }
.topbar .date-text { font-size:13px; color:var(--text-light); margin-top:2px; }

.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:16px; margin-bottom:24px; }

.stat-card {
    background:white;
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:20px;
    transition:all 0.2s;
}

.stat-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.stat-card .stat-top { display:flex; justify-content:space-between; align-items:flex-start; }
.stat-card .stat-icon { width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px; }
.stat-card .stat-value { font-size:28px; font-weight:800; margin-top:12px; }
.stat-card .stat-label { font-size:13px; color:var(--text-light); margin-top:2px; }

.icon-teal { background:rgba(13,148,136,0.1); color:var(--primary); }
.icon-green { background:rgba(34,197,94,0.1); color:var(--success); }
.icon-amber { background:rgba(245,158,11,0.1); color:var(--accent); }
.icon-red { background:rgba(239,68,68,0.1); color:var(--danger); }
.icon-blue { background:rgba(59,130,246,0.1); color:var(--info); }

.card { background:white; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.card-header { padding:16px 20px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; }
.card-header h3 { font-size:15px; font-weight:600; }
.card-body { padding:20px; }

.data-table { width:100%; border-collapse:collapse; }
.data-table thead th { padding:10px 14px; text-align:left; font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:0.3px; color:var(--text-light); background:var(--bg); border-bottom:1px solid var(--border); }
.data-table tbody td { padding:12px 14px; font-size:14px; border-bottom:1px solid #f1f5f9; color:var(--text-mid); }
.data-table tbody tr:hover { background:#f8fafc; }

.badge { display:inline-flex; padding:4px 10px; border-radius:20px; font-size:12px; font-weight:600; }
.badge-success { background:#dcfce7; color:#16a34a; }
.badge-warning { background:#fef9c3; color:#a16207; }
.badge-danger { background:#fef2f2; color:#dc2626; }
.badge-info { background:#dbeafe; color:#2563eb; }

/* ===== ABSENSI PAGE ===== */
.absen-page { min-height:100vh; background:var(--bg); padding:16px; display:flex; align-items:center; justify-content:center; }

.absen-container { width:100%; max-width:480px; }

.absen-topbar { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; }
.absen-topbar .user-info { display:flex; align-items:center; gap:10px; }
.absen-topbar .avatar { width:40px;height:40px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:white;font-weight:700;font-size:16px; }

.absen-clock-card { background:white; border-radius:var(--radius); padding:24px; text-align:center; margin-bottom:16px; border:1px solid var(--border); box-shadow:var(--shadow-sm); }
.absen-clock-card .time-display { font-size:52px; font-weight:800; color:var(--primary); letter-spacing:2px; font-variant-numeric:tabular-nums; }
.absen-clock-card .date-display { font-size:14px; color:var(--text-light); margin-top:4px; }

.camera-card { background:white; border-radius:var(--radius); overflow:hidden; margin-bottom:16px; border:1px solid var(--border); box-shadow:var(--shadow-sm); }
.camera-view { position:relative; background:#111; aspect-ratio:4/3; }
.camera-view video { width:100%;height:100%;object-fit:cover;display:block; }
.camera-view canvas { display:none; }
.camera-badge { position:absolute;top:12px;left:12px;background:rgba(0,0,0,0.6);color:white;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;backdrop-filter:blur(4px); }
.camera-radius { position:absolute;bottom:12px;right:12px;background:rgba(13,148,136,0.85);color:white;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;backdrop-filter:blur(4px); }

.gps-bar { padding:14px 16px; display:flex; align-items:center; gap:10px; font-size:13px; color:var(--text-mid); border-top:1px solid var(--border); }
.gps-dot { width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:blink 1.2s infinite; }
.gps-bar.ok .gps-dot { background:var(--success);animation:none; }
.gps-bar.fail .gps-dot { background:var(--danger);animation:none; }
@keyframes blink { 0%,100%{opacity:1}50%{opacity:0.3} }

.status-card { background:white; border-radius:var(--radius); padding:20px; margin-bottom:16px; border:1px solid var(--border); box-shadow:var(--shadow-sm); }
.status-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.status-item { background:var(--bg); padding:12px; border-radius:var(--radius-sm); text-align:center; }
.status-item .label { font-size:11px; color:var(--text-light); text-transform:uppercase; font-weight:600; letter-spacing:0.3px; }
.status-item .val { font-size:18px; font-weight:700; margin-top:4px; color:var(--text-dark); }

.btn-absen { width:100%;padding:16px;font-size:16px;font-weight:700;border-radius:var(--radius);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all 0.2s;font-family:inherit;color:white; }
.btn-absen-masuk { background:var(--success); }
.btn-absen-masuk:hover { background:#16a34a;box-shadow:0 4px 20px rgba(34,197,94,0.3); }
.btn-absen-keluar { background:var(--danger); }
.btn-absen-keluar:hover { background:#dc2626;box-shadow:0 4px 20px rgba(239,68,68,0.3); }
.btn-absen:disabled { opacity:0.5;cursor:not-allowed; }

.done-card { background:white;border-radius:var(--radius);padding:40px 24px;text-align:center;border:1px solid var(--border); }
.done-card .done-icon { width:72px;height:72px;border-radius:50%;background:#dcfce7;display:inline-flex;align-items:center;justify-content:center;font-size:36px;margin-bottom:16px; }
.done-card h3 { font-weight:700;margin-bottom:6px; }
.done-card p { color:var(--text-light);font-size:14px; }

/* ===== MOBILE ===== */
.menu-toggle { display:none;position:fixed;top:16px;left:16px;z-index:200;width:40px;height:40px;border-radius:var(--radius-sm);background:var(--primary);border:none;color:white;font-size:16px;cursor:pointer;align-items:center;justify-content:center; }
.sidebar-overlay { display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.3);z-index:99; }
.sidebar-overlay.show { display:block; }

@media(max-width:768px) {
    .login-page { grid-template-columns:1fr; }
    .login-banner { display:none; }
    .sidebar { transform:translateX(-100%); }
    .sidebar.open { transform:translateX(0); }
    .main-content { margin-left:0; }
    .menu-toggle { display:flex; }
    .stats-grid { grid-template-columns:1fr 1fr; }
    .topbar { padding-top:48px; }
}

@media(max-width:480px) {
    .stats-grid { grid-template-columns:1fr; }
    .absen-clock-card .time-display { font-size:40px; }
    .status-grid { grid-template-columns:1fr 1fr; }
}

/* ===== MISC ===== */
.empty-state { text-align:center;padding:40px 20px;color:var(--text-light); }
.empty-state i { font-size:48px;margin-bottom:12px;display:block;opacity:0.4; }
.text-center { text-align:center; }
.mt-3 { margin-top:12px; }
.mb-3 { margin-bottom:12px; }
.gap-2 { gap:8px; }
.d-flex { display:flex; }
.flex-wrap { flex-wrap:wrap; }

/* Form in modal/admin */
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:480px) { .form-row { grid-template-columns:1fr; } }
