@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;700&display=swap');

:root {
    --primary: #2d5a27;
    --primary-dark: #1e3d1a;
    --secondary: #d4af37;
    --accent: #e9c46a;
    --bg-main: #f0f2f5;
    --glass: rgba(255,255,255,0.92);
    --glass-border: rgba(255,255,255,0.25);
    --shadow: 0 8px 32px 0 rgba(31,38,135,0.13);
    --radius: 14px;
    --sidebar-width: 190px;
}

/* ===== BASE ===== */
body {
    font-family: 'Outfit', sans-serif !important;
    background-color: var(--bg-main) !important;
}

/* ===== NAVBAR ===== */
.navbar.navbar-default {
    background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
    border: none !important;
    box-shadow: 0 2px 20px rgba(0,0,0,0.18);
    min-height: 56px;
}
.navbar-brand small {
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #fff !important;
}
.navbar-container { padding: 0 15px; }

/* User menu label */
.light-blue .user-info small { color: rgba(255,255,255,0.75); font-size: 11px; display: block; }
.light-blue > a { color: #fff !important; }

/* Hamburger bar color */
.navbar-toggle .icon-bar { background: #fff !important; }

/* ===== SIDEBAR ===== */
.no-skin .sidebar {
    background: var(--glass) !important;
    backdrop-filter: blur(12px);
    border-right: 1px solid var(--glass-border) !important;
    box-shadow: 3px 0 20px rgba(0,0,0,0.08);
    width: var(--sidebar-width);
}
.no-skin .nav-list > li {
    border: none !important;
    margin: 3px 8px;
    border-radius: var(--radius);
    transition: all 0.25s ease;
}
.no-skin .nav-list > li.active { background: var(--primary) !important; }
.no-skin #sidebar.sidebar .nav-list > li.active > a,
.no-skin #sidebar.sidebar .nav-list > li.active > a:hover,
.no-skin #sidebar.sidebar .nav-list > li.active > a:focus {
    background-color: var(--primary) !important;
    color: #fff !important;
    font-weight: 600 !important;
}
.no-skin .nav-list > li > a { border-radius: var(--radius); transition: all 0.25s; }
.no-skin .nav-list > li > a:hover { background: rgba(45,90,39,0.1) !important; }
.no-skin .nav-list > li > a .menu-icon { color: var(--primary) !important; }
.no-skin #sidebar.sidebar .nav-list > li.active > a .menu-icon { color: #fff !important; }

/* ===== MAIN CONTENT ===== */
.main-content { background: transparent; }
.page-content { animation: fadeInUp 0.45s ease-out; }

/* Breadcrumbs */
.breadcrumbs {
    background: transparent !important;
    border: none !important;
    padding-left: 20px !important;
    box-shadow: none !important;
}

/* Page header */
.page-header { border-bottom: 2px solid rgba(45,90,39,0.12) !important; margin-bottom: 20px; }
.page-header h1 { color: var(--primary-dark); font-weight: 700; font-size: 22px; }

/* ===== WIDGET ===== */
.widget-box {
    border-radius: var(--radius) !important;
    border: none !important;
    box-shadow: var(--shadow) !important;
    overflow: hidden;
    margin-bottom: 22px;
}
.widget-header { background: #fff !important; border-bottom: 1px solid #eee !important; }
.widget-main { padding: 20px !important; }

/* ===== BUTTONS ===== */
.btn {
    border-radius: 8px !important;
    font-weight: 600 !important;
    transition: all 0.25s ease !important;
    min-height: 36px;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 5px 15px rgba(0,0,0,0.12); }
.btn-primary { background: var(--primary) !important; border: none !important; color: #fff !important; }
.btn-success { background: #27ae60 !important; border: none !important; }
.btn-warning { background: var(--secondary) !important; border: none !important; }
.btn-info { background: #2980b9 !important; border: none !important; color: #fff !important; }
.btn-danger { background: #c0392b !important; border: none !important; }

/* Custom premium colored buttons to override template defaults */
.btn-excel-premium {
    background: linear-gradient(135deg, #1d6f42, #2e9c5e) !important;
    color: #fff !important;
    border: none !important;
}
.btn-excel-premium:hover {
    background: linear-gradient(135deg, #155230, #227345) !important;
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(29,111,66,0.3) !important;
}
.btn-print-premium {
    background: linear-gradient(135deg, #e67e22, #d35400) !important;
    color: #fff !important;
    border: none !important;
}
.btn-print-premium:hover {
    background: linear-gradient(135deg, #b86214, #a03e00) !important;
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(230,126,34,0.3) !important;
}

/* ===== TABLE ===== */
.table { background: #fff; border-radius: var(--radius); overflow: hidden; margin-bottom: 0; }
.table thead th {
    background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
    color: #fff !important;
    border: none !important;
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: 0.8px;
    padding: 13px 10px !important;
}
.table tbody tr { transition: background 0.2s; }
.table tbody tr:hover { background: rgba(45,90,39,0.04) !important; }
.table tbody td { vertical-align: middle !important; padding: 10px !important; border-color: #f0f0f0 !important; }
.table-responsive {
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    width: 100%;
    margin-bottom: 15px;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
}
.table td, .table th {
    white-space: nowrap;
}

/* ===== BADGE NILAI ===== */
.badge-nilai {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 20px;
    font-weight: 700;
    font-size: 13px;
    min-width: 50px;
    text-align: center;
}
.badge-a { background: #d4edda; color: #155724; }
.badge-b { background: #cce5ff; color: #004085; }
.badge-c { background: #fff3cd; color: #856404; }
.badge-d { background: #f8d7da; color: #721c24; }

/* ===== STAT CARDS (DASHBOARD) ===== */
.stat-card {
    border-radius: var(--radius);
    padding: 22px 20px;
    color: #fff !important;
    text-decoration: none !important;
    display: block;
    transition: all 0.35s cubic-bezier(0.175,0.885,0.32,1.275);
    position: relative;
    overflow: hidden;
    margin-bottom: 18px;
    min-height: 110px;
}
.stat-card:hover { transform: translateY(-8px); box-shadow: 0 18px 40px rgba(0,0,0,0.2); color: #fff !important; text-decoration: none !important; }
.stat-card i { position: absolute; right: -8px; bottom: -8px; font-size: 70px; opacity: 0.18; transform: rotate(-12deg); }
.stat-card h3 { margin: 0 0 6px 0; font-size: 34px; font-weight: 700; line-height: 1; }
.stat-card p { margin: 0; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; font-size: 12px; opacity: 0.9; }

.bg-grad-1 { background: linear-gradient(135deg,#11998e,#38ef7d) !important; }
.bg-grad-2 { background: linear-gradient(135deg,#FF512F,#DD2476) !important; }
.bg-grad-3 { background: linear-gradient(135deg,#4776E6,#8E54E9) !important; }
.bg-grad-4 { background: linear-gradient(135deg,#f2994a,#f2c94c) !important; }
.bg-grad-5 { background: linear-gradient(135deg,#1A2980,#26D0CE) !important; }

/* ===== WELCOME ALERT ===== */
.alert-premium {
    background: #fff !important;
    border: none !important;
    border-left: 5px solid var(--primary) !important;
    box-shadow: var(--shadow) !important;
    border-radius: var(--radius) !important;
    padding: 24px 28px !important;
    margin-bottom: 24px;
}
.alert-premium h1 { color: var(--primary-dark); font-weight: 700; margin-top: 0; font-size: 24px; }
.alert-premium .text-muted { font-size: 14px; }

/* ===== FORM ===== */
.form-control {
    border-radius: 8px !important;
    border: 1px solid #dde3ec !important;
    padding: 10px 14px !important;
    height: auto !important;
    font-size: 14px;
    transition: all 0.25s;
    font-family: 'Outfit', sans-serif !important;
}
.form-control:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(45,90,39,0.12) !important;
    outline: none !important;
}
select.form-control, select.col-xs-10, select.col-sm-5 {
    border-radius: 8px !important;
    border: 1px solid #dde3ec !important;
    padding: 8px 12px !important;
    font-family: 'Outfit', sans-serif !important;
}
input[type="text"].col-xs-10,
input[type="text"].col-sm-5,
input[type="number"].col-xs-10,
input[type="number"].col-sm-5 {
    border-radius: 8px !important;
    border: 1px solid #dde3ec !important;
    padding: 8px 12px !important;
    height: auto !important;
    font-family: 'Outfit', sans-serif !important;
    transition: all 0.25s;
}
input[type="text"]:focus, input[type="number"]:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(45,90,39,0.12) !important;
    outline: none !important;
}
input[readonly] { background: #f5f6fa !important; color: #888 !important; }

.form-group { margin-bottom: 16px; }
.control-label { font-weight: 600; color: #444; }

/* Nilai auto-calc display */
.nilai-preview {
    background: linear-gradient(135deg, var(--primary), #38a32a);
    color: #fff;
    padding: 12px 20px;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 700;
    margin-top: 8px;
    display: inline-block;
}

/* ===== TOAST NOTIFICATION ===== */
.toast-container {
    position: fixed;
    top: 70px;
    right: 20px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.toast-msg {
    min-width: 280px;
    max-width: 360px;
    padding: 14px 20px 14px 18px;
    border-radius: 12px;
    box-shadow: 0 8px 30px rgba(0,0,0,0.15);
    display: flex;
    align-items: center;
    gap: 12px;
    font-weight: 600;
    font-size: 14px;
    animation: slideInRight 0.4s cubic-bezier(0.175,0.885,0.32,1.275) forwards;
    position: relative;
    color: #fff;
}
.toast-msg.toast-success { background: linear-gradient(135deg,#11998e,#27ae60); }
.toast-msg.toast-error   { background: linear-gradient(135deg,#c0392b,#e74c3c); }
.toast-msg.toast-info    { background: linear-gradient(135deg,#2980b9,#6dd5fa); }
.toast-msg i { font-size: 20px; flex-shrink: 0; }
.toast-msg .toast-close {
    position: absolute; right: 10px; top: 50%; transform: translateY(-50%);
    cursor: pointer; opacity: 0.7; font-size: 16px; background: none; border: none; color: #fff;
}
.toast-msg.fade-out { animation: fadeOut 0.4s ease forwards; }

/* ===== SIDEBAR MOBILE OVERLAY ===== */
.sidebar-overlay {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.5);
    z-index: 1049 !important;
}
.sidebar-overlay.active { display: block; }

/* Sidebar User Info (Default Hidden) */
.sidebar-user-info { display: none; }

/* ===== FOOTER ===== */
.footer { background: #fff !important; border-top: 1px solid #eee; }
.footer .bigger-120 { font-size: 14px; color: #666; }
.footer .blue { color: var(--primary); }

/* ===== SCROLL UP BTN ===== */
.btn-scroll-up {
    background: var(--primary) !important;
    border: none !important;
    border-radius: 50% !important;
    width: 42px; height: 42px;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 15px rgba(45,90,39,0.4);
}

/* ===== LOGIN PAGE ===== */
.login-layout {
    background: linear-gradient(rgba(10,25,15,0.7), rgba(10,25,15,0.82)),
        url('https://images.unsplash.com/photo-1542810634-71277d95dcbb?q=80&w=2070&auto=format&fit=crop') no-repeat center center fixed;
    background-size: cover !important;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}
.login-container { width: 440px !important; margin: 0 auto; animation: slideUpFade 0.9s cubic-bezier(0.175,0.885,0.32,1.275) forwards; }
.login-box {
    background: rgba(255,255,255,0.13) !important;
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    border: 1px solid rgba(255,255,255,0.28) !important;
    border-radius: 24px !important;
    padding: 38px !important;
    box-shadow: 0 15px 40px rgba(0,0,0,0.25);
    animation: floating 6s ease-in-out infinite;
    animation-delay: 1s;
}
.login-box .header { border-bottom: 2px solid rgba(255,255,255,0.15) !important; padding-bottom: 18px !important; text-align: center; font-weight: 700; }
.login-box label { margin-bottom: 18px; display: block; }
.login-box .input-icon input {
    background: rgba(255,255,255,0.5) !important;
    border: 1px solid rgba(0,0,0,0.1) !important;
    color: #111 !important;
    border-radius: 12px !important;
    padding: 14px 14px 14px 44px !important;
    height: 50px;
    font-size: 15px;
}
.login-box .input-icon input::placeholder { color: rgba(0,0,0,0.45) !important; }
.login-box .input-icon input:focus { border-color: var(--secondary) !important; box-shadow: 0 0 15px rgba(212,175,55,0.3) !important; outline: none; }
.login-box .input-icon i { color: var(--secondary) !important; font-size: 17px !important; left: 14px !important; top: 50% !important; transform: translateY(-50%) !important; }
.login-box .btn-primary {
    background: linear-gradient(135deg,var(--secondary),#b8962e) !important;
    color: #111 !important;
    border-radius: 12px !important;
    padding: 13px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    width: 100% !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    box-shadow: 0 5px 18px rgba(212,175,55,0.4) !important;
}
.login-box .btn-primary:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(212,175,55,0.6) !important; }
.login-welcome-text { text-align: center; margin-bottom: 28px; }
.login-welcome-text h1 { color: #fff; font-weight: 700; text-shadow: 0 2px 10px rgba(0,0,0,0.5); margin: 0 0 8px; }
.login-welcome-text .sub-text { color: var(--secondary); font-size: 18px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; }

/* ===== LANDING PAGE ===== */
header {
    background: linear-gradient(rgba(45,90,39,0.72), rgba(30,61,26,0.82)),
        url('https://images.unsplash.com/photo-1519810755548-39cd217da494?q=80&w=2000&auto=format&fit=crop') !important;
    background-size: cover !important;
    min-height: 100vh !important;
    display: flex !important;
    align-items: center !important;
    color: #fff !important;
}
.intro-text .intro-lead-in { font-family:'Outfit',sans-serif !important; font-size: 22px !important; font-style: normal !important; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 8px !important; }
.intro-text .intro-heading { font-family:'Outfit',sans-serif !important; font-weight: 700 !important; font-size: 52px !important; line-height: 1.15 !important; text-shadow: 0 4px 15px rgba(0,0,0,0.3); }
.navbar-custom { background-color: transparent !important; padding: 15px 0; transition: all 0.4s; border: none !important; }
.navbar-custom .navbar-brand { font-family:'Outfit',sans-serif !important; font-weight: 700 !important; color: var(--secondary) !important; }
.navbar-custom .nav li a { font-family:'Outfit',sans-serif !important; font-weight: 600 !important; text-transform: uppercase; letter-spacing: 1px; }
section { padding: 80px 0 !important; }
.section-heading { font-weight: 700 !important; color: var(--primary-dark); text-transform: uppercase; letter-spacing: 1px; }
.timeline-image { border: 7px solid #f1f3f5 !important; }
#contact { background: linear-gradient(rgba(45,90,39,0.92),rgba(45,90,39,0.92)),url('https://images.unsplash.com/photo-1432821596592-e2c18b78144f?q=80&w=2070&auto=format&fit=crop') !important; }
#contact .form-control { background: rgba(255,255,255,0.1) !important; border: 1px solid rgba(255,255,255,0.2) !important; color: #fff !important; }
#contact .form-control::placeholder { color: rgba(255,255,255,0.55); }
#contact .section-heading { color: #fff !important; }

/* ===== ANIMATIONS ===== */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(22px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes slideUpFade {
    0%   { opacity: 0; transform: translateY(50px); }
    100% { opacity: 1; transform: translateY(0); }
}
@keyframes floating {
    0%   { transform: translateY(0px); }
    50%  { transform: translateY(-8px); }
    100% { transform: translateY(0px); }
}
@keyframes slideInRight {
    from { opacity: 0; transform: translateX(80px); }
    to   { opacity: 1; transform: translateX(0); }
}
@keyframes fadeOut {
    from { opacity: 1; transform: translateX(0); }
    to   { opacity: 0; transform: translateX(80px); }
}

/* ===== RESPONSIVE — TABLET (≤992px) ===== */
@media (max-width: 992px) {
    .intro-text .intro-heading { font-size: 38px !important; }
    .stat-card h3 { font-size: 28px; }
}

/* ===== RESPONSIVE — MOBILE (≤991px) ===== */
@media (max-width: 991px) {

    /* Navbar */
    .navbar.navbar-default { min-height: 50px; }
    .navbar-brand small { font-size: 13px !important; letter-spacing: 0.5px; }
    .navbar-container { padding: 0 8px; }
    .navbar-buttons { display: none !important; } /* sembunyikan dropdown user di mobile, sudah ada di sidebar */
    .sidebar-user-info { display: block !important; }

    /* Sidebar: overlay mode */
    #sidebar.sidebar {
        position: fixed !important;
        top: 0 !important;
        left: -220px !important;
        height: 100% !important;
        max-height: none !important;
        z-index: 1050 !important;
        transition: left 0.3s ease !important;
        width: 220px !important;
        overflow-y: auto;
        padding-top: 56px;
    }
    #sidebar.sidebar.mobile-open {
        left: 0 !important;
        margin-left: 0 !important;
        transform: none !important;
        -webkit-transform: none !important;
    }

    /* Main content full width di mobile */
    .main-content {
        margin-left: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Breadcrumb */
    .breadcrumbs { padding-left: 10px !important; font-size: 12px; }

    /* Page header */
    .page-header { padding: 10px 15px; }
    .page-header h1 { font-size: 17px !important; }

    /* Page content padding */
    .page-content { padding: 10px 8px !important; }

    /* Stat cards: 2 kolom di mobile */
    .stat-card { padding: 16px 14px; min-height: 90px; margin-bottom: 12px; }
    .stat-card h3 { font-size: 26px; }
    .stat-card i { font-size: 55px; }
    .stat-card p { font-size: 11px; }

    /* Alert premium */
    .alert-premium { padding: 16px 18px !important; }
    .alert-premium h1 { font-size: 18px; }

    /* Form: label di atas input (bukan samping) */
    .form-horizontal .control-label {
        text-align: left !important;
        padding-bottom: 4px !important;
        width: 100% !important;
        float: none !important;
    }
    .form-horizontal .col-sm-3 {
        width: 100% !important;
        float: none !important;
        padding-right: 0 !important;
    }
    .form-horizontal .col-sm-9,
    .form-horizontal .col-md-9 {
        width: 100% !important;
        float: none !important;
        padding-left: 0 !important;
    }
    .form-horizontal .col-xs-10,
    .form-horizontal .col-sm-5 {
        width: 100% !important;
    }
    select.col-xs-10, select.col-sm-5 { width: 100% !important; display: block !important; }
    input.col-xs-10, input.col-sm-5 { width: 100% !important; display: block !important; }

    /* Form actions button */
    .form-actions .col-md-offset-3 { margin-left: 0 !important; }
    .form-actions .col-md-9 { width: 100% !important; float: none !important; }
    .form-actions .btn { width: 100% !important; margin-bottom: 8px !important; }

    /* Table — scroll horizontal */
    .table-responsive { overflow-x: auto !important; -webkit-overflow-scrolling: touch; }
    .table td, .table th { white-space: nowrap; font-size: 13px; padding: 10px 8px !important; }

    /* Tombol aksi tabel — lebih besar untuk tap */
    .btn-acsi { display: inline-block; padding: 7px 12px !important; margin: 2px; font-size: 13px !important; }

    /* Toast */
    .toast-container { top: 58px; right: 10px; left: 10px; }
    .toast-msg { min-width: auto; max-width: 100%; }

    /* Sidebar toggle button */
    #menu-toggler.navbar-toggle.menu-toggler {
        background: rgba(255, 255, 255, 0.12) !important;
        border: 1px solid rgba(255, 255, 255, 0.25) !important;
        border-radius: 8px !important;
        padding: 8px 10px !important;
        margin-top: 8px !important;
        margin-bottom: 8px !important;
        margin-left: 8px !important;
        float: left !important;
        display: block !important;
        transition: all 0.2s ease !important;
    }
    #menu-toggler.navbar-toggle.menu-toggler:hover,
    #menu-toggler.navbar-toggle.menu-toggler:active,
    #menu-toggler.navbar-toggle.menu-toggler:focus {
        background: rgba(255, 255, 255, 0.22) !important;
        border-color: rgba(255, 255, 255, 0.5) !important;
        outline: none !important;
    }
    #menu-toggler.navbar-toggle.menu-toggler .icon-bar {
        background-color: #ffffff !important;
        width: 18px !important;
        height: 2px !important;
        display: block !important;
        border-radius: 1px !important;
        transition: all 0.2s ease !important;
    }
    #menu-toggler.navbar-toggle.menu-toggler .icon-bar + .icon-bar {
        margin-top: 4px !important;
    }

    /* Login */
    .login-container { width: 95% !important; padding: 0 10px; }
    .login-box { padding: 24px 18px !important; }

    /* Landing */
    .intro-text .intro-heading { font-size: 28px !important; }
    .intro-text .intro-lead-in { font-size: 14px !important; }
    section { padding: 50px 0 !important; }
    .navbar-custom { padding: 8px 0; }
}

/* ===== RESPONSIVE — SMALL MOBILE (≤480px) ===== */
@media (max-width: 480px) {
    .stat-card h3 { font-size: 22px; }
    .page-header h1 { font-size: 15px !important; }
    .alert-premium h1 { font-size: 16px; }
    .table td, .table th { font-size: 12px; padding: 8px 6px !important; }
    .intro-text .intro-heading { font-size: 22px !important; }
}

/* ===== PREMIUM MODAL SYSTEM ===== */
.premium-modal-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(12, 30, 18, 0.72) !important; /* Hijau gelap transparan */
    z-index: 999999 !important;
    display: none;
    justify-content: center;
    align-items: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}
.premium-modal-overlay.active {
    display: flex !important;
    opacity: 1 !important;
}
.premium-modal-card {
    background: #ffffff !important;
    border-radius: 20px !important;
    box-shadow: 0 20px 50px rgba(12, 30, 18, 0.3) !important;
    border: 1px solid rgba(255, 255, 255, 0.8) !important;
    padding: 30px !important;
    width: 90% !important;
    max-width: 420px !important;
    text-align: center !important;
    position: relative !important;
    transform: scale(0.8) !important;
    transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}
.premium-modal-overlay.active .premium-modal-card {
    transform: scale(1) !important;
}
.premium-modal-close-btn {
    position: absolute !important;
    top: 15px !important;
    right: 18px !important;
    background: none !important;
    border: none !important;
    font-size: 26px !important;
    color: #94a3b8 !important;
    cursor: pointer !important;
    transition: color 0.2s ease !important;
    line-height: 1 !important;
    padding: 0 !important;
}
.premium-modal-close-btn:hover {
    color: #1e293b !important;
}

/* Modal Icon */
.premium-modal-icon-container {
    display: flex !important;
    justify-content: center !important;
    margin-bottom: 20px !important;
}
.premium-modal-icon {
    width: 68px !important;
    height: 68px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 28px !important;
}
.premium-modal-icon.icon-warning {
    border: 3px solid #eab308 !important;
    color: #eab308 !important;
    background: rgba(234, 179, 8, 0.08) !important;
}
.premium-modal-icon.icon-logout {
    border: 3px solid #ef4444 !important;
    color: #ef4444 !important;
    background: rgba(239, 68, 68, 0.08) !important;
}
.premium-modal-icon.icon-success {
    border: 3px solid #22c55e !important;
    color: #22c55e !important;
    background: rgba(34, 197, 94, 0.08) !important;
}

/* Modal Texts */
.premium-modal-title {
    font-family: 'Montserrat', 'Outfit', sans-serif !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: #2d5a27 !important;
    margin: 0 0 10px 0 !important;
}
.premium-modal-subtitle {
    font-size: 13.5px !important;
    color: #64748b !important;
    margin: 0 0 20px 0 !important;
}
.premium-modal-body {
    font-size: 14.5px !important;
    color: #334155 !important;
    line-height: 1.6 !important;
    margin-bottom: 24px !important;
}

/* Modal Buttons */
.premium-modal-footer {
    display: flex !important;
    gap: 12px !important;
    justify-content: center !important;
}
.btn-premium-modal {
    padding: 10px 24px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    border: none !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.btn-premium-modal-ok,
.btn-premium-modal-confirm {
    background: linear-gradient(135deg, #2d5a27, #1e3d1a) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 12px rgba(45, 90, 39, 0.25) !important;
}
.btn-premium-modal-ok:hover,
.btn-premium-modal-confirm:hover {
    box-shadow: 0 6px 16px rgba(45, 90, 39, 0.4) !important;
    transform: translateY(-1px) !important;
    color: #ffffff !important;
}
.btn-premium-modal-cancel {
    background: #f1f5f9 !important;
    color: #475569 !important;
    border: 1px solid #e2e8f0 !important;
}
.btn-premium-modal-cancel:hover {
    background: #e2e8f0 !important;
    color: #1e293b !important;
}

/* ===== SPECIFIC FOR LOGIN POPUP ===== */
.premium-modal-logo-container {
    margin-bottom: 15px !important;
}
.premium-modal-logo-container img {
    height: 55px !important;
    width: auto !important;
}
.login-modal-card {
    max-width: 440px !important;
    padding: 35px 30px 25px 30px !important;
    border: 1px solid rgba(45, 90, 39, 0.2) !important;
    background: rgba(255, 255, 255, 0.98) !important;
}

/* Role Selection Tabs */
.login-role-tabs {
    display: flex !important;
    border-bottom: 1px solid #f1f5f9 !important;
    margin-bottom: 18px !important;
    background: #f8fafc !important;
    border-radius: 12px !important;
    padding: 4px !important;
}
.login-role-tab {
    flex: 1 !important;
    text-align: center !important;
    padding: 10px 0 !important;
    cursor: pointer !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    color: #64748b !important;
    font-weight: 600 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 4px !important;
    border-radius: 8px !important;
    font-size: 12px !important;
}
.login-role-tab:hover {
    color: #2d5a27 !important;
    background: rgba(45, 90, 39, 0.04) !important;
}
.login-role-tab.active {
    color: #ffffff !important;
    background: #2d5a27 !important;
    box-shadow: 0 4px 10px rgba(45, 90, 39, 0.2) !important;
}
.login-role-tab i {
    font-size: 16px !important;
    transition: transform 0.2s ease !important;
}
.login-role-tab.active i {
    transform: scale(1.1) !important;
}
.login-role-desc {
    background: #f0fdf4 !important;
    border-left: 4px solid #cda224 !important;
    padding: 12px 15px !important;
    border-radius: 4px 8px 8px 4px !important;
    font-size: 12px !important;
    color: #334155 !important;
    text-align: left !important;
    margin-bottom: 20px !important;
    line-height: 1.5 !important;
    min-height: 56px !important;
}

.premium-form-group {
    position: relative !important;
    margin-bottom: 16px !important;
    text-align: left !important;
}
.premium-input-icon {
    position: absolute !important;
    left: 14px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    color: #94a3b8 !important;
    font-size: 15px !important;
}
.premium-form-control {
    width: 100% !important;
    padding: 12px 16px 12px 42px !important;
    border-radius: 10px !important;
    border: 1px solid #cbd5e1 !important;
    font-size: 14px !important;
    color: #1e293b !important;
    background: #f8fafc !important;
    transition: all 0.2s ease !important;
    outline: none !important;
}
.premium-form-control:focus {
    border-color: #2d5a27 !important;
    background: #ffffff !important;
    box-shadow: 0 0 0 3px rgba(45, 90, 39, 0.15) !important;
}
.btn-premium-login-submit {
    width: 100% !important;
    padding: 12px !important;
    border-radius: 10px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    background: linear-gradient(135deg, #cda224, #a37f17) !important;
    border: none !important;
    cursor: pointer !important;
    box-shadow: 0 4px 15px rgba(205, 162, 36, 0.3) !important;
    transition: all 0.2s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    margin-top: 24px !important;
}
.btn-premium-login-submit:hover {
    box-shadow: 0 6px 20px rgba(205, 162, 36, 0.45) !important;
    transform: translateY(-1px) !important;
}
.premium-modal-notice {
    margin-top: 20px !important;
    padding-top: 15px !important;
    border-top: 1px solid #f1f5f9 !important;
    font-size: 11.5px !important;
    color: #64748b !important;
    line-height: 1.5 !important;
}
.premium-modal-notice i {
    color: #2d5a27 !important;
    margin-right: 4px !important;
}
