/* Phase 12.1 — Premium Glassmorphism Theme
   UI/theme only. No payroll, commission, PNL, import or permission logic changes. */
:root {
    --tm-night-1: #07111f;
    --tm-night-2: #111b3d;
    --tm-night-3: #24124f;
    --tm-blue: #3b82f6;
    --tm-cyan: #22d3ee;
    --tm-violet: #8b5cf6;
    --tm-purple: #c026d3;
    --tm-pink: #ec4899;
    --tm-amber: #f59e0b;
    --tm-green: #10b981;
    --tm-red: #ef4444;
    --tm-text: #182033;
    --tm-muted: #6b7280;
    --tm-line: rgba(255,255,255,.18);
    --tm-glass-dark: rgba(9, 17, 38, .72);
    --tm-glass-mid: rgba(255,255,255,.12);
    --tm-glass-card: rgba(255,255,255,.82);
    --tm-glass-card-strong: rgba(255,255,255,.94);
    --tm-shadow-lg: 0 1.4rem 4rem rgba(0,0,0,.24);
    --tm-shadow-md: 0 .85rem 2.2rem rgba(15,23,42,.16);
    --tm-radius-xl: 1.35rem;
    --tm-radius-lg: 1rem;
}

html { scroll-behavior: smooth; }
body.glass-theme,
body.nav-fixed.glass-theme,
body.login-bg.glass-theme {
    min-height: 100vh;
    color: var(--tm-text);
    background:
        radial-gradient(circle at 12% 10%, rgba(34,211,238,.28) 0, rgba(34,211,238,0) 22rem),
        radial-gradient(circle at 84% 4%, rgba(192,38,211,.38) 0, rgba(192,38,211,0) 27rem),
        radial-gradient(circle at 72% 82%, rgba(59,130,246,.28) 0, rgba(59,130,246,0) 27rem),
        linear-gradient(135deg, var(--tm-night-1) 0%, var(--tm-night-2) 48%, var(--tm-night-3) 100%) !important;
    background-attachment: fixed;
    font-feature-settings: "cv02", "cv03", "cv04", "cv11";
}
body.glass-theme::before,
body.login-bg.glass-theme::before {
    content: "";
    position: fixed;
    width: 28rem;
    height: 28rem;
    right: -9rem;
    top: 4.5rem;
    border-radius: 999px;
    background: radial-gradient(circle at 36% 32%, rgba(236,72,153,.85), rgba(139,92,246,.55) 42%, rgba(59,130,246,0) 72%);
    filter: blur(.2px);
    opacity: .86;
    z-index: -2;
    pointer-events: none;
}
body.glass-theme::after,
body.login-bg.glass-theme::after {
    content: "";
    position: fixed;
    width: 18rem;
    height: 18rem;
    left: 40%;
    bottom: 6rem;
    border-radius: 999px;
    background: radial-gradient(circle at 35% 35%, rgba(34,211,238,.6), rgba(59,130,246,.35) 48%, rgba(34,211,238,0) 74%);
    opacity: .72;
    z-index: -2;
    pointer-events: none;
}
body.glass-theme .container-xl { position: relative; }

/* Top navigation */
.glass-theme .topnav.navbar {
    background: rgba(7,17,31,.72) !important;
    backdrop-filter: blur(22px) saturate(1.45);
    -webkit-backdrop-filter: blur(22px) saturate(1.45);
    border-bottom: 1px solid rgba(255,255,255,.12);
    box-shadow: 0 .65rem 1.7rem rgba(0,0,0,.18) !important;
}
.glass-theme .navbar-light .navbar-brand,
.glass-theme .navbar-light .navbar-brand:hover,
.glass-theme .brand-text { color: #fff !important; }
.glass-theme .topnav .text-muted { color: rgba(226,232,240,.62) !important; }
.glass-theme .btn-transparent-dark,
.glass-theme .navbar-light .navbar-nav .nav-link { color: rgba(255,255,255,.78) !important; }
.glass-theme .btn-transparent-dark:hover { color: #fff !important; background: rgba(255,255,255,.08) !important; }
.glass-theme .brand-mark {
    width: 2.1rem;
    height: 2.1rem;
    border-radius: .85rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--tm-cyan), var(--tm-violet) 55%, var(--tm-pink)) !important;
    color: #fff;
    font-weight: 950;
    box-shadow: 0 .75rem 1.5rem rgba(139,92,246,.42), inset 0 1px 0 rgba(255,255,255,.32) !important;
}
.glass-theme .badge-soft-primary,
.glass-theme .topnav .badge {
    background: rgba(139,92,246,.18) !important;
    border: 1px solid rgba(255,255,255,.18);
    color: rgba(255,255,255,.9) !important;
}

/* Sidebar */
.glass-theme #layoutSidenav #layoutSidenav_nav .sidenav,
.glass-theme .sidenav-light {
    background: rgba(8,18,38,.76) !important;
    backdrop-filter: blur(24px) saturate(1.35);
    -webkit-backdrop-filter: blur(24px) saturate(1.35);
    border-right: 1px solid rgba(255,255,255,.12);
    box-shadow: .8rem 0 2.8rem rgba(0,0,0,.16) !important;
}
.glass-theme .sidenav-menu-heading {
    color: rgba(203,213,225,.46) !important;
    font-size: .67rem !important;
    letter-spacing: .11em;
    font-weight: 900;
}
.glass-theme .sidenav-light .sidenav-menu .nav-link {
    color: rgba(226,232,240,.78) !important;
    border-radius: .95rem;
    margin: .08rem .75rem;
    padding: .82rem .9rem;
    transition: transform .16s ease, background .16s ease, color .16s ease, box-shadow .16s ease;
}
.glass-theme .sidenav-light .sidenav-menu .nav-link .nav-link-icon,
.glass-theme .sidenav-light .sidenav-menu .nav-link svg { color: rgba(226,232,240,.58) !important; }
.glass-theme .sidenav-light .sidenav-menu .nav-link:hover {
    color: #fff !important;
    background: rgba(255,255,255,.08) !important;
    transform: translateX(3px);
}
.glass-theme .sidenav-light .sidenav-menu .nav-link:hover .nav-link-icon,
.glass-theme .sidenav-light .sidenav-menu .nav-link:hover svg { color: #fff !important; }
.glass-theme .sidenav-light .sidenav-menu .nav-link.active {
    color: #fff !important;
    background: linear-gradient(135deg, rgba(59,130,246,.98), rgba(139,92,246,.98) 52%, rgba(192,38,211,.94)) !important;
    box-shadow: 0 .85rem 1.65rem rgba(59,130,246,.28), inset 0 1px rgba(255,255,255,.2) !important;
}
.glass-theme .sidenav-light .sidenav-menu .nav-link.active .nav-link-icon,
.glass-theme .sidenav-light .sidenav-menu .nav-link.active svg { color: #fff !important; }
.glass-theme .sidenav-footer {
    background: rgba(255,255,255,.06) !important;
    color: rgba(226,232,240,.82) !important;
    border-top: 1px solid rgba(255,255,255,.12);
}
.glass-theme .sidenav-footer .small { color: rgba(203,213,225,.62) !important; }

/* Hero header */
.glass-theme .page-header {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(15,23,42,.72), rgba(30,41,89,.62) 45%, rgba(88,28,135,.58)) !important;
    border-bottom: 1px solid rgba(255,255,255,.10);
    box-shadow: inset 0 -1px rgba(255,255,255,.08);
}
.glass-theme .page-header::before {
    content: "";
    position: absolute;
    width: 26rem;
    height: 15rem;
    right: 9rem;
    top: 3.1rem;
    border-radius: 2.2rem;
    transform: rotate(7deg);
    background: linear-gradient(135deg, rgba(255,255,255,.22), rgba(255,255,255,.055));
    border: 1px solid rgba(255,255,255,.22);
    box-shadow: inset 0 1px rgba(255,255,255,.22), 0 1.8rem 4rem rgba(0,0,0,.26);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    z-index: -1;
    pointer-events: none;
}
.glass-theme .page-header::after {
    content: "";
    position: absolute;
    width: 12rem;
    height: 12rem;
    right: 20rem;
    bottom: -5.5rem;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(236,72,153,.95), rgba(139,92,246,.55) 52%, rgba(236,72,153,0) 75%);
    z-index: -2;
    pointer-events: none;
}
.glass-theme .page-header-title {
    color: #fff !important;
    font-weight: 950 !important;
    letter-spacing: -.045em;
    text-shadow: 0 1rem 2.2rem rgba(0,0,0,.22);
}
.glass-theme .page-header-subtitle { color: rgba(226,232,240,.72) !important; font-weight: 550; }
.glass-theme .page-header-icon {
    width: 2.6rem;
    height: 2.6rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,.13);
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 1rem;
    margin-right: .72rem;
    box-shadow: inset 0 1px rgba(255,255,255,.16);
}
.glass-theme .page-header .badge.bg-white {
    background: rgba(255,255,255,.16) !important;
    border: 1px solid rgba(255,255,255,.22);
    color: #fff !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

/* Content surfaces */
.glass-theme #layoutSidenav_content main > .container-xl,
.glass-theme .container-xl.mt-n10 { z-index: 2; }
.glass-theme .card,
.glass-theme .filter-card,
.glass-theme .quick-action-card,
.glass-theme .dropdown-menu,
.glass-theme .alert {
    background: var(--tm-glass-card) !important;
    border: 1px solid rgba(255,255,255,.58) !important;
    border-radius: var(--tm-radius-xl) !important;
    box-shadow: var(--tm-shadow-md) !important;
    backdrop-filter: blur(22px) saturate(1.2);
    -webkit-backdrop-filter: blur(22px) saturate(1.2);
}
.glass-theme .card-header {
    background: rgba(255,255,255,.62) !important;
    border-bottom: 1px solid rgba(255,255,255,.72) !important;
    color: #16213f;
    font-weight: 850;
    border-top-left-radius: var(--tm-radius-xl) !important;
    border-top-right-radius: var(--tm-radius-xl) !important;
}
.glass-theme .card-body,
.glass-theme .list-group-item { color: var(--tm-text); }
.glass-theme .list-group-item {
    background: rgba(255,255,255,.36) !important;
    border-color: rgba(15,23,42,.06) !important;
}
.glass-theme .list-group-item-action:hover { background: rgba(139,92,246,.10) !important; color: #4c1d95; }

/* KPI cards */
.glass-theme .totel-kpi-card {
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(145deg, rgba(255,255,255,.94), rgba(255,255,255,.66)) !important;
    border: 1px solid rgba(255,255,255,.74) !important;
    box-shadow: 0 1.2rem 2.6rem rgba(15,23,42,.14) !important;
    transition: transform .18s ease, box-shadow .18s ease;
}
.glass-theme .totel-kpi-card:hover { transform: translateY(-3px); box-shadow: 0 1.5rem 3.2rem rgba(15,23,42,.20) !important; }
.glass-theme .totel-kpi-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 88% 0%, rgba(139,92,246,.18), rgba(139,92,246,0) 38%),
        linear-gradient(90deg, rgba(59,130,246,.16), rgba(236,72,153,.10));
    opacity: .95;
    pointer-events: none;
}
.glass-theme .totel-kpi-card::after {
    content: "";
    position: absolute;
    width: 5.6rem;
    height: 5.6rem;
    right: -1.8rem;
    top: -1.8rem;
    background: radial-gradient(circle, rgba(59,130,246,.18), rgba(59,130,246,0) 68%) !important;
    border-radius: 999px;
}
.glass-theme .totel-kpi-card .card-body { position: relative; z-index: 1; }
.glass-theme .totel-kpi-label {
    color: rgba(24,32,51,.58) !important;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .075em;
    font-weight: 900;
}
.glass-theme .totel-kpi-value {
    color: #0f172a !important;
    font-size: clamp(1.22rem, 2vw, 1.72rem);
    font-weight: 950;
    letter-spacing: -.045em;
    line-height: 1.1;
}
.glass-theme .totel-kpi-value.text-success { color: #047857 !important; }
.glass-theme .totel-kpi-value.text-danger { color: #b91c1c !important; }

/* Tables — readable, not too transparent */
.glass-theme .table-responsive {
    background: rgba(255,255,255,.66);
    border: 1px solid rgba(15,23,42,.06);
    border-radius: 1rem;
    overflow: auto;
}
.glass-theme .table { color: #1f2937; margin-bottom: 0; }
.glass-theme .table thead th {
    background: rgba(248,250,252,.92);
    color: #64748b;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .055em;
    font-weight: 900;
    border-bottom: 1px solid rgba(15,23,42,.08);
    white-space: nowrap;
}
.glass-theme .table td,
.glass-theme .table th { vertical-align: middle; border-color: rgba(15,23,42,.06); }
.glass-theme .table-hover tbody tr:hover { background: rgba(139,92,246,.06); }

/* Form and buttons */
.glass-theme .form-control,
.glass-theme .form-select {
    background-color: rgba(255,255,255,.82);
    border: 1px solid rgba(15,23,42,.11);
    border-radius: .9rem;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.6);
}
.glass-theme .form-control:focus,
.glass-theme .form-select:focus {
    border-color: rgba(139,92,246,.55);
    box-shadow: 0 0 0 .22rem rgba(139,92,246,.14);
}
.glass-theme .btn { border-radius: .9rem; font-weight: 800; }
.glass-theme .btn-primary {
    border: 0 !important;
    color: #fff !important;
    background: linear-gradient(135deg, var(--tm-blue), var(--tm-violet) 58%, var(--tm-purple)) !important;
    box-shadow: 0 .7rem 1.35rem rgba(59,130,246,.26) !important;
}
.glass-theme .btn-primary:hover { transform: translateY(-1px); filter: brightness(1.04); }
.glass-theme .btn-outline-primary {
    color: #4f46e5 !important;
    border-color: rgba(79,70,229,.28) !important;
    background: rgba(255,255,255,.62) !important;
}
.glass-theme .btn-outline-primary:hover { background: rgba(79,70,229,.12) !important; }

/* Badges */
.glass-theme .badge-soft-success { color:#047857!important; background-color:rgba(16,185,129,.14)!important; border:1px solid rgba(16,185,129,.18); }
.glass-theme .badge-soft-warning { color:#92400e!important; background-color:rgba(245,158,11,.18)!important; border:1px solid rgba(245,158,11,.20); }
.glass-theme .badge-soft-danger { color:#b91c1c!important; background-color:rgba(239,68,68,.14)!important; border:1px solid rgba(239,68,68,.18); }
.glass-theme .badge-soft-info { color:#0369a1!important; background-color:rgba(34,211,238,.14)!important; border:1px solid rgba(34,211,238,.18); }
.glass-theme .badge-soft-primary { color:#4f46e5!important; background-color:rgba(139,92,246,.14)!important; border:1px solid rgba(139,92,246,.18); }

/* Timeline and utility surfaces */
.glass-theme .timeline .timeline-item-marker-text { color: rgba(24,32,51,.55); font-weight: 800; }
.glass-theme .dropdown-menu { background: rgba(255,255,255,.92) !important; }
.glass-theme .footer-admin {
    background: transparent !important;
    color: rgba(226,232,240,.55) !important;
    border-top: 0 !important;
}

/* Login premium screen */
body.login-bg.glass-theme { overflow-x: hidden; }
.glass-theme .auth-shell { min-height: 100vh; display: flex; align-items: center; padding: 2rem 0; }
.glass-theme .auth-copy { color: #fff; }
.glass-theme .auth-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    color: rgba(226,232,240,.76);
    font-size: .8rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: 1.1rem;
}
.glass-theme .auth-title {
    font-size: clamp(2.4rem, 5vw, 4.8rem);
    line-height: .95;
    letter-spacing: -.07em;
    font-weight: 950;
    margin-bottom: 1.2rem;
}
.glass-theme .auth-title .gradient-text,
.glass-theme .gradient-text {
    background: linear-gradient(135deg, #67e8f9, #a78bfa 45%, #f0abfc);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.glass-theme .auth-subtitle { color: rgba(226,232,240,.68); max-width: 34rem; font-size: 1.05rem; }
.glass-theme .auth-feature-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: .75rem; margin-top: 2rem; }
.glass-theme .auth-feature {
    background: rgba(255,255,255,.09);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 1.05rem;
    padding: .9rem;
    color: rgba(255,255,255,.86);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.glass-theme .auth-feature strong { display: block; color: #fff; font-size: 1.05rem; }
.glass-theme .login-card-wrap {
    position: relative;
}
.glass-theme .login-card-wrap::before {
    content: "";
    position: absolute;
    width: 11rem;
    height: 11rem;
    right: -4.5rem;
    top: -4.5rem;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(236,72,153,.88), rgba(139,92,246,.42) 55%, rgba(236,72,153,0) 75%);
    z-index: 0;
}
.glass-theme .login-card-wrap::after {
    content: "";
    position: absolute;
    width: 12rem;
    height: 12rem;
    left: -5rem;
    bottom: -5rem;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(34,211,238,.62), rgba(59,130,246,.3) 54%, rgba(34,211,238,0) 76%);
    z-index: 0;
}
.glass-theme .login-card {
    position: relative;
    z-index: 1;
    background: rgba(255,255,255,.14) !important;
    border: 1px solid rgba(255,255,255,.22) !important;
    box-shadow: 0 2rem 5rem rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.18) !important;
    color: #fff;
}
.glass-theme .login-card .card-header,
.glass-theme .login-card .card-footer {
    background: rgba(255,255,255,.08) !important;
    border-color: rgba(255,255,255,.14) !important;
    color: rgba(255,255,255,.86) !important;
}
.glass-theme .login-card label { color: rgba(255,255,255,.78); font-weight: 800; }
.glass-theme .login-card .form-control {
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    color: #fff;
}
.glass-theme .login-card .form-control::placeholder { color: rgba(255,255,255,.42); }
.glass-theme .login-card .form-control:focus { background: rgba(255,255,255,.16); border-color: rgba(255,255,255,.42); color:#fff; }
.glass-theme .login-logo {
    width: 3.3rem;
    height: 3.3rem;
    border-radius: 1.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--tm-cyan), var(--tm-violet), var(--tm-pink));
    color: #fff;
    font-weight: 950;
    font-size: 1.55rem;
    box-shadow: 0 1rem 2rem rgba(139,92,246,.38);
}
.glass-theme .login-meta-card {
    margin-top: 1rem;
    padding: 1rem;
    border-radius: 1.15rem;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.14);
    color: rgba(255,255,255,.74);
}

/* Responsive */
@media (max-width: 991.98px) {
    .glass-theme .page-header { padding-bottom: 7rem !important; }
    .glass-theme .page-header::before { right: -9rem; opacity: .5; }
    .glass-theme .page-header::after { right: 5rem; opacity: .7; }
    .glass-theme .page-header-title { font-size: 1.55rem; }
    .glass-theme .topnav .navbar-brand .brand-text { display: none; }
    .glass-theme .table-responsive table { min-width: 760px; }
    .glass-theme .auth-feature-grid { grid-template-columns: 1fr; }
    .glass-theme .auth-copy { text-align: center; margin-bottom: 2rem; }
    .glass-theme .auth-subtitle { margin-left: auto; margin-right: auto; }
}
@media (max-width: 575.98px) {
    .glass-theme .card,
    .glass-theme .filter-card,
    .glass-theme .quick-action-card { border-radius: 1rem !important; }
    .glass-theme .btn { width: 100%; margin-bottom: .35rem; }
    .glass-theme .filter-card .card-body { align-items: stretch !important; }
    .glass-theme .filter-card select,
    .glass-theme .filter-card input,
    .glass-theme .filter-card button,
    .glass-theme .filter-card a { width: 100%; }
    .glass-theme .dropdown-menu { max-width: calc(100vw - 1rem); }
}
@media print {
    body.glass-theme { background:#fff !important; color:#000 !important; }
    .glass-theme .topnav, .glass-theme #layoutSidenav_nav, .glass-theme .footer-admin, .glass-theme .btn, .glass-theme .filter-card { display:none !important; }
    .glass-theme #layoutSidenav_content { margin-left:0 !important; }
    .glass-theme .container-xl { max-width:100% !important; }
    .glass-theme .card { background:#fff !important; box-shadow:none !important; border:1px solid #ddd !important; }
}
