*,*::before,*::after{box-sizing:border-box}html{font-size:14px;scroll-behavior:smooth}body{margin:0;padding:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",sans-serif;background:#020617;color:#e5e7eb;line-height:1.5;-webkit-font-smoothing:antialiased}img{max-width:100%;height:auto}a{color:#60a5fa;text-decoration:none;transition:color 0.15s ease,opacity 0.15s ease}a:hover{color:#93c5fd}.layout-root{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(circle at 0% 0%,rgba(59,130,246,0.2),transparent 55%),radial-gradient(circle at 100% 100%,rgba(16,185,129,0.18),transparent 55%),#020617}.app-header{position:sticky;top:0;z-index:50;border-bottom:1px solid rgba(15,23,42,0.8);background:linear-gradient( to right,rgba(15,23,42,0.97),rgba(15,23,42,0.92) );backdrop-filter:blur(18px)}.app-header-inner{max-width:1180px;margin:0 auto;padding:0.45rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:0.9rem}.brand{display:flex;align-items:center;gap:0.7rem}.brand-logo{width:2.1rem;height:2.1rem;border-radius:0.9rem;background:radial-gradient(circle at 0 0,#38bdf8,transparent 55%),radial-gradient(circle at 100% 100%,#22c55e,transparent 55%),#1d4ed8;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:0.95rem;color:#f9fafb;box-shadow:0 8px 20px rgba(15,23,42,0.8),0 0 0 1px rgba(148,163,184,0.35)}.brand-text{display:flex;flex-direction:column}.brand-title{font-size:0.98rem;font-weight:700;letter-spacing:0.01em;color:#e5e7eb}.brand-subtitle{font-size:0.75rem;color:#9ca3af}.header-right{display:flex;align-items:center;gap:0.5rem}.header-user{display:flex;align-items:center;gap:0.5rem}.header-user-info{display:flex;flex-direction:column;align-items:flex-end}.header-user-name{font-size:0.8rem;font-weight:600;color:#e5e7eb}.header-user-role{font-size:0.7rem;color:#9ca3af}.avatar-initial{width:2rem;height:2rem;border-radius:999px;background:radial-gradient(circle at 0 0,#60a5fa,#1d4ed8);color:#eff6ff;display:inline-flex;align-items:center;justify-content:center;font-size:0.85rem;font-weight:700;box-shadow:0 6px 18px rgba(15,23,42,0.7)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:0.3rem;padding:0.33rem 0.85rem;border-radius:999px;font-size:0.78rem;font-weight:500;border:1px solid transparent;cursor:pointer;text-decoration:none;white-space:nowrap;background:transparent;color:#e5e7eb;transition:background-color 0.15s ease,border-color 0.15s ease,color 0.15s ease,transform 0.08s ease}.btn-sm{padding:0.25rem 0.65rem;font-size:0.75rem}.btn:hover{transform:translateY(-0.5px)}.btn-primary{background:linear-gradient(to right,#2563eb,#4f46e5);border-color:transparent;color:#eff6ff;box-shadow:0 8px 16px rgba(37,99,235,0.35)}.btn-primary:hover{background:linear-gradient(to right,#1d4ed8,#4338ca)}.btn-outline{border-color:rgba(148,163,184,0.6);background:rgba(15,23,42,0.7);color:#e5e7eb}.btn-outline:hover{border-color:#60a5fa;background:rgba(15,23,42,0.95)}.btn-danger{background:linear-gradient(to right,#dc2626,#b91c1c);border-color:transparent;color:#fee2e2;box-shadow:0 8px 16px rgba(185,28,28,0.35)}.btn-danger:hover{background:linear-gradient(to right,#b91c1c,#991b1b)}.btn[disabled],.btn:disabled{opacity:0.5;cursor:not-allowed;box-shadow:none}.app-main{flex:1 1 auto;padding:1.4rem 1.25rem 1.8rem}.app-main-inner{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr);gap:1rem}.layout-with-sidebar{grid-template-columns:230px minmax(0,1fr);align-items:flex-start}.sidebar{border-radius:0.9rem;border:1px solid rgba(15,23,42,0.85);padding:0.85rem 0.75rem;background:radial-gradient(circle at 0 0,rgba(59,130,246,0.18),transparent 65%),rgba(15,23,42,0.96);box-shadow:0 18px 40px rgba(15,23,42,0.9),0 0 0 1px rgba(30,64,175,0.2)}.sidebar-title{font-size:0.8rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:#9ca3af;margin:0 0 0.45rem;padding:0 0.2rem}.sidebar-item{font-size:0.8rem;color:#e5e7eb;margin:0.2rem 0}.sidebar-item a{color:inherit}.sidebar-menu{list-style:none;padding:0;margin:0}.sidebar-menu-item{margin-bottom:0.1rem}.sidebar-link{display:flex;align-items:center;justify-content:space-between;gap:0.5rem;font-size:0.8rem;color:#e5e7eb;padding:0.34rem 0.55rem;border-radius:0.6rem;transition:background 0.15s ease,color 0.15s ease,transform 0.08s ease}.sidebar-link span.label{display:flex;align-items:center;gap:0.4rem}.sidebar-link small.badge{background:rgba(15,23,42,0.9);border-radius:999px;padding:0.06rem 0.45rem;font-size:0.7rem;color:#9ca3af;border:1px solid rgba(55,65,81,0.9)}.sidebar-link:hover{background:rgba(30,64,175,0.7);text-decoration:none;transform:translateY(-0.5px)}.sidebar-link-active{background:linear-gradient(135deg,rgba(37,99,235,0.8),rgba(22,163,74,0.8));border-radius:0.6rem;box-shadow:0 12px 28px rgba(15,23,42,0.9)}.sidebar-link-active span.label{color:#f9fafb}.page-card{border-radius:1rem;border:1px solid rgba(30,64,175,0.4);background:radial-gradient(circle at 0 0,rgba(37,99,235,0.15),transparent 60%),radial-gradient(circle at 100% 100%,rgba(16,185,129,0.12),transparent 60%),rgba(15,23,42,0.96);padding:1.3rem 1.3rem 1.4rem;box-shadow:0 24px 60px rgba(15,23,42,0.95),0 0 0 1px rgba(15,23,42,0.9)}.page-title{margin:0 0 0.4rem;font-size:1.25rem;font-weight:700;letter-spacing:0.01em;color:#f9fafb}.page-subtitle{margin:0 0 0.9rem;font-size:0.85rem;color:#9ca3af}.page-content{margin-top:0.1rem}.alerts{margin-bottom:0.8rem;display:flex;flex-direction:column;gap:0.35rem}.alert{border-radius:0.7rem;padding:0.55rem 0.7rem;font-size:0.8rem;border:1px solid transparent;display:flex;align-items:flex-start;gap:0.45rem}.alert-success{background:rgba(22,163,74,0.12);border-color:rgba(74,222,128,0.35);color:#bbf7d0}.alert-error{background:rgba(239,68,68,0.12);border-color:rgba(252,165,165,0.5);color:#fecaca}.alert-info{background:rgba(59,130,246,0.13);border-color:rgba(147,197,253,0.55);color:#bfdbfe}.dash-card{background:rgba(15,23,42,0.96);border-radius:0.85rem;border:1px solid rgba(31,41,55,0.95);padding:0.95rem 1rem;box-shadow:0 14px 35px rgba(15,23,42,0.9)}.dash-card-soft{background:rgba(30,64,175,0.15);border-radius:0.85rem;border:1px solid rgba(129,140,248,0.6);padding:0.9rem 0.95rem;font-size:0.8rem;color:#e0f2fe}.dash-section-title{font-size:0.95rem;font-weight:600;margin:0 0 0.35rem;color:#e5e7eb}.dash-section-subtitle{font-size:0.8rem;color:#9ca3af;margin:0 0 0.6rem}.badge-soft-sky,.badge-soft-green,.badge-soft-amber,.badge-soft-slate{display:inline-flex;align-items:center;gap:0.25rem;padding:0.1rem 0.6rem;border-radius:999px;font-size:0.75rem}.badge-soft-sky{background:rgba(56,189,248,0.2);color:#e0f2fe}.badge-soft-green{background:rgba(34,197,94,0.22);color:#bbf7d0}.badge-soft-amber{background:rgba(251,191,36,0.22);color:#fef3c7}.badge-soft-slate{background:rgba(148,163,184,0.22);color:#e5e7eb}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0.75rem;margin-top:0.35rem}.stat-card{background:rgba(15,23,42,0.96);border-radius:0.75rem;border:1px solid rgba(31,41,55,0.95);padding:0.7rem 0.8rem}.stat-card.highlight{border-color:rgba(59,130,246,0.9);box-shadow:0 0 0 1px rgba(59,130,246,0.6)}.stat-label{font-size:0.75rem;color:#9ca3af;margin-bottom:0.18rem}.stat-value{font-size:1.1rem;font-weight:700;color:#f9fafb}.stat-caption{font-size:0.75rem;color:#6b7280}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:0.8rem}.table th,.table td{padding:0.45rem 0.4rem;border-bottom:1px solid rgba(31,41,55,0.9);text-align:left}.table th{font-weight:600;color:#9ca3af;font-size:0.78rem;white-space:nowrap}.table td{color:#e5e7eb;vertical-align:top}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:rgba(15,23,42,0.9)}.form-group{margin-bottom:0.55rem}.form-label{font-size:0.8rem;font-weight:500;color:#e5e7eb;display:block;margin-bottom:0.25rem}.form-input,.form-select,.form-textarea{width:100%;box-sizing:border-box;border-radius:0.55rem;border:1px solid rgba(55,65,81,0.9);font-size:0.8rem;padding:0.32rem 0.45rem;background:rgba(15,23,42,0.95);color:#e5e7eb;transition:border-color 0.12s ease,box-shadow 0.12s ease,background-color 0.12s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 1px rgba(59,130,246,0.7);background:#020617}.form-textarea{min-height:3.2rem;resize:vertical}.form-hint{font-size:0.75rem;color:#6b7280;margin-top:0.18rem}.form-row-inline{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0.45rem}.form-checkbox-row{display:flex;align-items:center;gap:0.35rem;font-size:0.8rem;color:#e5e7eb}.form-checkbox-row input[type="checkbox"]{width:0.9rem;height:0.9rem}.label-small{font-size:0.72rem;color:#6b7280}.status-pill{display:inline-flex;align-items:center;gap:0.25rem;padding:0.1rem 0.55rem;border-radius:999px;font-size:0.75rem;border:1px solid transparent}.status-draft{background:rgba(148,163,184,0.25);border-color:rgba(148,163,184,0.6);color:#e5e7eb}.status-active{background:rgba(34,197,94,0.2);border-color:rgba(74,222,128,0.6);color:#bbf7d0}.status-archived{background:rgba(31,41,55,0.9);border-color:rgba(75,85,99,0.9);color:#9ca3af}.status-user-active{background:rgba(34,197,94,0.2);border-color:rgba(74,222,128,0.6);color:#bbf7d0}.status-user-suspended{background:rgba(239,68,68,0.16);border-color:rgba(252,165,165,0.8);color:#fecaca}.status-user-pending{background:rgba(251,191,36,0.22);border-color:rgba(252,211,77,0.8);color:#fef3c7}.status-user-deleted{background:rgba(31,41,55,0.9);border-color:rgba(55,65,81,0.9);color:#9ca3af}.empty-note{font-size:0.8rem;color:#9ca3af}.hint-box{margin-top:0.4rem;padding:0.55rem 0.65rem;border-radius:0.6rem;background:rgba(15,23,42,0.96);border:1px dashed rgba(75,85,99,0.9);font-size:0.78rem;color:#e5e7eb}.ay-grid,.um-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1.2fr);gap:1.25rem}.ay-main,.ay-side,.um-main,.um-side{display:flex;flex-direction:column;gap:1rem}.app-footer{border-top:1px solid rgba(15,23,42,0.9);padding:0.75rem 1.25rem 1.2rem;font-size:0.78rem;color:#6b7280;background:rgba(15,23,42,0.98)}.app-footer-inner{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:0.5rem;flex-wrap:wrap}.badge-soft{display:inline-flex;align-items:center;gap:0.25rem;font-size:0.75rem;padding:0.08rem 0.45rem;border-radius:999px;background:rgba(31,41,55,0.9);color:#9ca3af}@media (max-width:1024px){.layout-with-sidebar{grid-template-columns:210px minmax(0,1fr)}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:860px){.app-main-inner{grid-template-columns:minmax(0,1fr)}.layout-with-sidebar{grid-template-columns:minmax(0,1fr)}.sidebar{position:static;order:-1;margin-bottom:0.3rem}.ay-grid,.um-grid{grid-template-columns:minmax(0,1fr)}}@media (max-width:640px){.app-header-inner{flex-direction:column;align-items:flex-start}.header-right{width:100%;justify-content:space-between}.header-user-info{align-items:flex-start}.stats-grid{grid-template-columns:minmax(0,1fr)}}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}:root{--color-primary:#2563eb;--color-primary-soft:#eff6ff;--color-primary-dark:#1d4ed8;--color-success:#16a34a;--color-success-soft:#ecfdf5;--color-danger:#dc2626;--color-danger-soft:#fef2f2;--color-warning:#d97706;--color-warning-soft:#fffbeb;--color-info:#0ea5e9;--color-info-soft:#e0f2fe;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-400:#9ca3af;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2933;--color-gray-900:#111827;--color-border:var(--color-gray-200);--color-body-bg:#f3f4f6;--color-body-text:var(--color-gray-800);--header-height:56px;--sidebar-width:235px;--sidebar-width-collapsed:64px;--container-max-width:1200px;--radius-sm:0.35rem;--radius-md:0.55rem;--radius-lg:0.75rem;--radius-pill:999px;--shadow-sm:0 1px 2px rgba(15,23,42,0.06);--shadow-md:0 1px 3px rgba(15,23,42,0.12);--shadow-soft:0 10px 25px rgba(15,23,42,0.06);--transition-fast:150ms ease-out;--transition-normal:200ms ease-out;--font-sans:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}body{font-family:var(--font-sans);font-size:0.95rem;line-height:1.5;background-color:var(--color-body-bg);color:var(--color-body-text);-webkit-font-smoothing:antialiased}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark);text-decoration:underline}img{max-width:100%;height:auto}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 1.2rem;background-color:#ffffff;border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:40}.app-header-left,.app-header-right{display:flex;align-items:center;gap:0.75rem}.app-logo{display:flex;align-items:center;gap:0.5rem}.app-logo-icon{width:28px;height:28px;border-radius:0.7rem;background:radial-gradient(circle at 20% 20%,#3b82f6,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#eff6ff;font-size:0.9rem;box-shadow:0 8px 18px rgba(37,99,235,0.35)}.app-logo-text{display:flex;flex-direction:column}.app-logo-title{font-size:0.95rem;font-weight:700;color:var(--color-gray-900)}.app-logo-subtitle{font-size:0.7rem;color:var(--color-gray-500)}.app-main{display:flex;flex:1;min-height:calc(100vh - var(--header-height))}.app-sidebar{width:var(--sidebar-width);background-color:#ffffff;border-right:1px solid var(--color-border);box-shadow:var(--shadow-sm);padding:0.6rem 0.5rem;display:flex;flex-direction:column;gap:0.4rem;position:sticky;top:var(--header-height);align-self:flex-start;max-height:calc(100vh - var(--header-height));overflow-y:auto}.app-sidebar-section-label{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.05em;color:var(--color-gray-400);padding:0.4rem 0.75rem 0.2rem}.sidebar-menu{list-style:none;padding:0.1rem 0.2rem;margin:0}.sidebar-menu li{margin-bottom:0.1rem}.sidebar-link{display:flex;align-items:center;gap:0.5rem;font-size:0.85rem;color:var(--color-gray-600);padding:0.35rem 0.65rem;border-radius:var(--radius-md);border:1px solid transparent;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.sidebar-link:hover{background-color:var(--color-gray-50);border-color:var(--color-gray-200);text-decoration:none}.sidebar-link.active{background-color:var(--color-primary-soft);border-color:var(--color-primary);color:var(--color-primary-dark);box-shadow:0 0 0 1px rgba(37,99,235,0.12)}.app-content{flex:1;padding:1rem 1.2rem 1.5rem}.app-content-inner{max-width:var(--container-max-width);margin:0 auto}.card{background-color:#ffffff;border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:1rem 1.1rem;box-shadow:var(--shadow-sm)}.card-soft{background-color:var(--color-gray-50);border-radius:var(--radius-md);border:1px dashed var(--color-border);padding:0.8rem 0.9rem;font-size:0.8rem;color:var(--color-gray-600)}.card-header{display:flex;align-items:baseline;justify-content:space-between;gap:0.5rem;margin-bottom:0.5rem}.card-title{font-size:0.95rem;font-weight:600;color:var(--color-gray-900)}.card-subtitle{font-size:0.8rem;color:var(--color-gray-500);margin-top:0.15rem}.dash-card{background:#f9fafb;border-radius:0.75rem;border:1px solid var(--color-border);padding:1rem 1.1rem}.dash-card-soft{background:var(--color-primary-soft);border-radius:0.75rem;border:1px solid #bfdbfe;padding:0.9rem 1rem;font-size:0.8rem;color:var(--color-primary-dark)}.dash-section-title{font-size:0.95rem;font-weight:600;margin:0 0 0.35rem}.dash-section-subtitle{font-size:0.8rem;color:var(--color-gray-500);margin:0 0 0.6rem}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0.85rem}.grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0.85rem}@media (max-width:900px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:640px){.grid-3{grid-template-columns:minmax(0,1fr)}}.text-muted{color:var(--color-gray-500)}.text-sm{font-size:0.8rem}.text-xs{font-size:0.72rem}.text-bold{font-weight:600}.text-center{text-align:center}.text-right{text-align:right}.btn{display:inline-flex;align-items:center;justify-content:center;gap:0.3rem;padding:0.32rem 0.7rem;border-radius:var(--radius-pill);font-size:0.8rem;font-weight:500;border:1px solid transparent;cursor:pointer;text-decoration:none;white-space:nowrap;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);background-color:#ffffff;color:var(--color-gray-700)}.btn:hover{box-shadow:var(--shadow-sm);transform:translateY(-0.5px);text-decoration:none}.btn-primary{background-color:var(--color-primary);border-color:var(--color-primary);color:#eff6ff}.btn-primary:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark)}.btn-outline{background-color:#ffffff;border-color:var(--color-border);color:var(--color-gray-700)}.btn-outline:hover{background-color:var(--color-gray-50)}.btn-danger{background-color:var(--color-danger);border-color:var(--color-danger);color:#fee2e2}.btn-danger:hover{background-color:#b91c1c;border-color:#b91c1c}.btn-ghost{background-color:transparent;border-color:transparent;color:var(--color-gray-600)}.btn-ghost:hover{background-color:var(--color-gray-100)}.btn-sm{padding:0.24rem 0.6rem;font-size:0.75rem}.btn-lg{padding:0.45rem 0.9rem;font-size:0.9rem}.btn[disabled],.btn:disabled{opacity:0.6;cursor:not-allowed;box-shadow:none;transform:none}.badge{display:inline-flex;align-items:center;gap:0.25rem;padding:0.08rem 0.55rem;border-radius:var(--radius-pill);font-size:0.75rem;border:1px solid transparent}.badge-soft-sky{background:#e0f2fe;color:#0369a1;border-color:#bae6fd}.badge-soft-green{background:#dcfce7;color:#166534;border-color:#bbf7d0}.badge-soft-amber{background:#fef3c7;color:#92400e;border-color:#fde68a}.badge-soft-slate{background:#e5e7eb;color:#4b5563;border-color:#d1d5db}.badge-soft-red{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.status-pill{display:inline-flex;align-items:center;gap:0.25rem;padding:0.1rem 0.55rem;border-radius:var(--radius-pill);font-size:0.75rem;border:1px solid transparent}.status-ok{background:#dcfce7;border-color:#bbf7d0;color:#166534}.status-warn{background:#fef3c7;border-color:#fde68a;color:#92400e}.status-danger{background:#fee2e2;border-color:#fecaca;color:#b91c1c}.status-neutral{background:#e5e7eb;border-color:#d1d5db;color:#4b5563}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:0.8rem}.table th,.table td{padding:0.45rem 0.5rem;border-bottom:1px solid var(--color-border);text-align:left}.table th{font-weight:600;color:var(--color-gray-600);font-size:0.78rem;white-space:nowrap;background-color:#f9fafb}.table tr:last-child td{border-bottom:none}.table tbody tr:nth-child(odd){background-color:#f9fafb}.table tbody tr:hover{background-color:#eff6ff}.form-group{margin-bottom:0.7rem}.form-label{font-size:0.8rem;font-weight:500;color:var(--color-gray-700);display:block;margin-bottom:0.25rem}.form-input,.form-select,.form-textarea{width:100%;box-sizing:border-box;border-radius:0.55rem;border:1px solid var(--color-border);font-size:0.8rem;padding:0.35rem 0.5rem;background-color:#ffffff;color:var(--color-gray-800);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px rgba(37,99,235,0.15)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-gray-400)}.form-textarea{min-height:80px;resize:vertical}.form-hint{font-size:0.75rem;color:var(--color-gray-500);margin-top:0.18rem}.flash-container{margin-bottom:0.8rem}.alert{padding:0.5rem 0.65rem;border-radius:0.6rem;font-size:0.8rem;border:1px solid transparent;display:flex;align-items:flex-start;gap:0.4rem;margin-bottom:0.35rem}.alert-icon{font-size:1rem;line-height:1}.alert-success{background-color:var(--color-success-soft);border-color:#bbf7d0;color:var(--color-success)}.alert-error{background-color:var(--color-danger-soft);border-color:#fecaca;color:var(--color-danger)}.alert-info{background-color:var(--color-info-soft);border-color:#bae6fd;color:var(--color-info)}.alert-warning{background-color:var(--color-warning-soft);border-color:#fed7aa;color:var(--color-warning)}.mt-0{margin-top:0 !important}.mt-1{margin-top:0.25rem !important}.mt-2{margin-top:0.5rem !important}.mt-3{margin-top:0.75rem !important}.mb-0{margin-bottom:0 !important}.mb-1{margin-bottom:0.25rem !important}.mb-2{margin-bottom:0.5rem !important}.mb-3{margin-bottom:0.75rem !important}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-between{justify-content:space-between}.flex-center{justify-content:center;align-items:center}.gap-1{gap:0.25rem}.gap-2{gap:0.5rem}.gap-3{gap:0.75rem}@media (max-width:920px){.app-main{flex-direction:column}.app-sidebar{width:100%;max-height:none;position:static;border-right:none;border-bottom:1px solid var(--color-border);flex-direction:row;flex-wrap:wrap;gap:0.3rem}.app-content{padding:0.9rem 0.85rem 1.2rem}.app-content-inner{max-width:100%}}@media (max-width:640px){.app-header{padding:0 0.8rem}.app-logo-subtitle{display:none}.app-header-right{gap:0.4rem}}.auth-shell{min-height:calc(100vh - var(--header-height));display:flex;align-items:center;justify-content:center;padding:1.2rem 0.8rem}.auth-wrapper{width:100%;max-width:960px;display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);gap:1rem;background:#ffffff;border-radius:1.1rem;border:1px solid var(--color-border);box-shadow:var(--shadow-soft);overflow:hidden}.auth-hero{position:relative;padding:1.5rem 1.4rem;background:radial-gradient(circle at 10% 0,#1d4ed8,#1e3a8a);color:#e5edff;display:flex;flex-direction:column;justify-content:space-between}.auth-hero-top{display:flex;flex-direction:column;gap:0.7rem}.auth-hero-title{font-size:1.2rem;font-weight:700}.auth-hero-subtitle{font-size:0.85rem;color:#c7d2fe}.auth-hero-list{margin:0.5rem 0 0.3rem 1.1rem;padding:0;font-size:0.78rem;color:#e5e7eb}.auth-hero-badge-row{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:0.6rem}.auth-hero-badge{display:inline-flex;align-items:center;gap:0.25rem;padding:0.12rem 0.55rem;border-radius:999px;font-size:0.75rem;background:rgba(15,23,42,0.3);border:1px solid rgba(191,219,254,0.4)}.auth-hero-counter{margin-top:1.1rem;font-size:0.78rem;color:#c7d2fe;display:flex;flex-wrap:wrap;gap:0.5rem}.auth-hero-counter span{display:inline-flex;align-items:center;gap:0.25rem}.auth-card{padding:1.4rem 1.4rem;display:flex;flex-direction:column;justify-content:center}.auth-card-header{margin-bottom:0.6rem}.auth-card-title{font-size:1rem;font-weight:600;color:var(--color-gray-900);margin-bottom:0.2rem}.auth-card-subtitle{font-size:0.8rem;color:var(--color-gray-500)}.auth-alt-link{font-size:0.8rem;margin-top:0.6rem;color:var(--color-gray-600)}.auth-info-box{margin-top:0.6rem;padding:0.55rem 0.65rem;background:var(--color-gray-50);border-radius:0.7rem;border:1px dashed var(--color-border);font-size:0.78rem;color:var(--color-gray-600)}@media (max-width:900px){.auth-wrapper{grid-template-columns:minmax(0,1fr)}.auth-hero{order:-1;padding-bottom:1.2rem}}.stat-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0.8rem}.stat-card{background:#ffffff;border-radius:0.8rem;border:1px solid var(--color-border);padding:0.7rem 0.8rem;box-shadow:var(--shadow-sm)}.stat-card.highlight{border-color:var(--color-primary);box-shadow:0 0 0 1px rgba(37,99,235,0.12)}.stat-label{font-size:0.75rem;color:var(--color-gray-500);margin-bottom:0.15rem}.stat-value{font-size:1.1rem;font-weight:700;color:var(--color-gray-900)}.stat-caption{font-size:0.75rem;color:var(--color-gray-400);margin-top:0.1rem}@media (max-width:1024px){.stat-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:640px){.stat-row{grid-template-columns:minmax(0,1fr)}}.metric-strip{display:flex;flex-wrap:wrap;gap:0.35rem;margin-top:0.35rem}.metric-pill{display:inline-flex;align-items:center;gap:0.25rem;padding:0.1rem 0.6rem;border-radius:999px;background:var(--color-gray-50);border:1px solid var(--color-border);font-size:0.75rem;color:var(--color-gray-600)}.tab-row{display:flex;flex-wrap:wrap;gap:0.4rem;margin:0.6rem 0 0.4rem;font-size:0.8rem}.tab-pill{display:inline-flex;align-items:center;gap:0.25rem;padding:0.22rem 0.7rem;border-radius:999px;border:1px solid var(--color-border);background:#ffffff;color:var(--color-gray-600);text-decoration:none;cursor:pointer;font-size:0.78rem;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.tab-pill:hover{background:var(--color-gray-50);text-decoration:none}.tab-pill.active{background:var(--color-primary);border-color:var(--color-primary);color:#eff6ff;box-shadow:0 0 0 1px rgba(37,99,235,0.18)}.tab-pill span.count{font-size:0.72rem;opacity:0.85}.filter-bar{display:flex;flex-wrap:wrap;gap:0.5rem;align-items:center;justify-content:space-between;margin-top:0.4rem}.filter-search-form{display:inline-flex;align-items:center;gap:0.35rem;margin:0}.filter-input{border-radius:999px;border:1px solid var(--color-border);padding:0.28rem 0.7rem;font-size:0.8rem;min-width:200px;background:#ffffff;color:var(--color-gray-800);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.filter-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px rgba(37,99,235,0.18)}.chip-list{margin-top:0.35rem;font-size:0.78rem;color:var(--color-gray-600)}.chip-list span{display:inline-flex;align-items:center;padding:0.1rem 0.5rem;border-radius:999px;background:var(--color-gray-100);margin:0 0.25rem 0.25rem 0}.role-badge{display:inline-flex;align-items:center;gap:0.25rem;padding:0.12rem 0.55rem;border-radius:999px;font-size:0.75rem;border:1px solid transparent}.role-admin-pusat{background:#1f2937;border-color:#4b5563;color:#e5e7eb}.role-admin-sekolah{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.role-guru{background:#ecfdf5;border-color:#bbf7d0;color:#15803d}.role-siswa{background:#eef2ff;border-color:#c7d2fe;color:#4f46e5}.role-tenaga-kependidikan{background:#fef3c7;border-color:#fde68a;color:#92400e}.steps-list{margin:0.3rem 0 0 1.1rem;padding:0;font-size:0.8rem;color:var(--color-gray-700)}.steps-list li{margin-bottom:0.18rem}.timeline{margin:0.4rem 0 0;padding-left:0;list-style:none;border-left:1px solid var(--color-border)}.timeline-item{padding-left:0.8rem;margin-bottom:0.5rem;position:relative}.timeline-item::before{content:'';position:absolute;left:-4px;top:0.2rem;width:8px;height:8px;border-radius:999px;background-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft)}.timeline-title{font-size:0.82rem;font-weight:600;color:var(--color-gray-800);margin-bottom:0.08rem}.timeline-meta{font-size:0.74rem;color:var(--color-gray-500)}.empty-state{padding:1rem 0.8rem;border-radius:0.8rem;border:1px dashed var(--color-border);background-color:var(--color-gray-50);text-align:center;font-size:0.82rem;color:var(--color-gray-600)}.empty-state-icon{font-size:1.4rem;margin-bottom:0.3rem}.empty-note{font-size:0.8rem;color:var(--color-gray-500)}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,0.35);z-index:50;display:flex;align-items:center;justify-content:center}.modal{background:#ffffff;border-radius:0.9rem;border:1px solid var(--color-border);box-shadow:var(--shadow-soft);max-width:480px;width:calc(100% - 2rem);padding:1rem 1.1rem}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:0.5rem;margin-bottom:0.4rem}.modal-title{font-size:0.95rem;font-weight:600;color:var(--color-gray-900)}.modal-body{font-size:0.82rem;color:var(--color-gray-700);margin-bottom:0.6rem}.modal-footer{display:flex;justify-content:flex-end;gap:0.4rem}.status-school,.status-sj{display:inline-flex;align-items:center;gap:0.25rem;padding:0.1rem 0.55rem;border-radius:999px;font-size:0.75rem;border:1px solid transparent}.status-school-pending,.status-sj-pending{background:#fef3c7;border-color:#fde68a;color:#92400e}.status-school-approved,.status-sj-active{background:#dcfce7;border-color:#bbf7d0;color:#166534}.status-school-rejected,.status-sj-inactive{background:#fee2e2;border-color:#fecaca;color:#b91c1c}.active-pill{display:inline-flex;align-items:center;gap:0.2rem;padding:0.08rem 0.5rem;border-radius:999px;font-size:0.72rem}.active-on{background:#dcfce7;color:#166534}.active-off{background:#f3f4f6;color:#4b5563}.page-grid-main-side{display:grid;grid-template-columns:minmax(0,2.3fr) minmax(0,1.1fr);gap:1.25rem}.page-main-column,.page-side-column{display:flex;flex-direction:column;gap:1rem}@media (max-width:860px){.page-grid-main-side{grid-template-columns:minmax(0,1fr)}}.tooltip{position:relative;cursor:help}.tooltip::after{content:attr(data-tooltip);position:absolute;left:50%;bottom:calc(100%+6px);transform:translateX(-50%);background:#111827;color:#f9fafb;padding:0.25rem 0.45rem;border-radius:0.35rem;font-size:0.7rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast),transform var(--transition-fast);transform-origin:bottom center;z-index:40}.tooltip:hover::after{opacity:1;transform:translateX(-50%) translateY(-2px)}.landing-hero{position:relative;padding:2.2rem 0 1.8rem;display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1.4fr);gap:1.8rem}.landing-hero-left{display:flex;flex-direction:column;gap:0.9rem;z-index:1}.landing-kicker{display:inline-flex;align-items:center;gap:0.4rem;padding:0.18rem 0.55rem;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:0.76rem}.landing-kicker span.tag{padding:0.08rem 0.4rem;border-radius:999px;background:#1d4ed8;color:#e5edff;font-weight:500}.landing-title{font-size:1.65rem;line-height:1.25;font-weight:700;color:#0f172a}.landing-title span.highlight{background:linear-gradient(90deg,#2563eb,#22c55e);-webkit-background-clip:text;background-clip:text;color:transparent}.landing-subtitle{font-size:0.9rem;color:#6b7280;max-width:32rem}.landing-hero-cta-row{display:flex;flex-wrap:wrap;gap:0.6rem;margin-top:0.4rem}.landing-hero-cta-row .btn{font-size:0.82rem}.landing-hero-note{font-size:0.78rem;color:#6b7280;margin-top:0.4rem}.landing-hero-stats{display:flex;flex-wrap:wrap;gap:0.7rem;margin-top:1rem;font-size:0.8rem;color:#4b5563}.landing-hero-stat-item{display:inline-flex;flex-direction:column;gap:0.05rem}.landing-hero-stat-label{font-size:0.76rem;color:#9ca3af}.landing-hero-stat-value{font-weight:600;color:#111827}.landing-hero-right{position:relative;display:flex;align-items:center;justify-content:center}.landing-hero-glow{position:absolute;inset:10%;background:radial-gradient(circle at 10% 0,rgba(59,130,246,0.18),transparent 60%),radial-gradient(circle at 100% 100%,rgba(34,197,94,0.16),transparent 60%);filter:blur(8px);opacity:0.9;pointer-events:none}.landing-hero-panel{position:relative;width:100%;max-width:360px;background:#ffffff;border-radius:1.2rem;border:1px solid #e5e7eb;box-shadow:0 18px 40px rgba(15,23,42,0.14);padding:0.9rem 0.95rem;display:flex;flex-direction:column;gap:0.6rem;z-index:1}.landing-hero-panel-header{display:flex;align-items:center;justify-content:space-between;gap:0.5rem}.landing-hero-panel-title{font-size:0.85rem;font-weight:600;color:#111827}.landing-hero-panel-tag{font-size:0.75rem;padding:0.08rem 0.5rem;border-radius:999px;background:#eff6ff;color:#1d4ed8}.landing-hero-roles{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0.45rem;margin-top:0.3rem}.landing-role-card{background:#f9fafb;border-radius:0.7rem;padding:0.45rem 0.5rem;border:1px solid #e5e7eb;font-size:0.76rem}.landing-role-title{font-weight:600;color:#111827;margin-bottom:0.1rem}.landing-role-desc{font-size:0.72rem;color:#6b7280}.landing-role-chip-row{margin-top:0.08rem;display:flex;flex-wrap:wrap;gap:0.18rem}.landing-role-chip{padding:0.05rem 0.35rem;border-radius:999px;background:#e5e7eb;font-size:0.68rem;color:#4b5563}.landing-hero-panel-stats{margin-top:0.5rem;padding-top:0.45rem;border-top:1px dashed #e5e7eb;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0.4rem}.landing-hero-panel-stat{font-size:0.72rem;color:#6b7280}.landing-hero-panel-stat strong{display:block;font-size:0.8rem;color:#111827}.landing-stats{margin-top:0.4rem;padding:0.85rem 0.9rem;border-radius:0.9rem;border:1px dashed #d1d5db;background:#f9fafb;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0.8rem;font-size:0.8rem}.landing-stat-item{display:flex;flex-direction:column;gap:0.12rem}.landing-stat-label{font-size:0.75rem;color:#9ca3af}.landing-stat-value{font-size:1.05rem;font-weight:700;color:#111827}.landing-stat-caption{font-size:0.75rem;color:#6b7280}@media (max-width:960px){.landing-hero{grid-template-columns:minmax(0,1fr);padding-top:1.6rem}.landing-hero-right{order:-1}.landing-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:640px){.landing-stats{grid-template-columns:minmax(0,1fr)}.landing-hero-panel{max-width:100%}}.landing-section{margin-top:1.4rem}.landing-section-header{display:flex;align-items:baseline;justify-content:space-between;gap:0.5rem;margin-bottom:0.4rem}.landing-section-title{font-size:0.95rem;font-weight:600;color:#111827}.landing-section-subtitle{font-size:0.8rem;color:#6b7280}.landing-section-right-link{font-size:0.78rem}.landing-content-grid{display:grid;grid-template-columns:minmax(0,2.1fr) minmax(0,1.1fr);gap:1rem}.landing-card-list{display:grid;grid-template-columns:minmax(0,1fr);gap:0.6rem}.landing-card{background:#ffffff;border-radius:0.85rem;border:1px solid #e5e7eb;padding:0.75rem 0.8rem;display:flex;flex-direction:column;gap:0.25rem;box-shadow:0 1px 2px rgba(15,23,42,0.06)}.landing-card-type-badge{display:inline-flex;align-items:center;gap:0.25rem;padding:0.08rem 0.5rem;border-radius:999px;font-size:0.72rem;background:#eff6ff;color:#1d4ed8}.landing-card-title{font-size:0.85rem;font-weight:600;color:#111827}.landing-card-meta{font-size:0.74rem;color:#9ca3af}.landing-card-author{font-size:0.76rem;color:#6b7280}.landing-card-tags{margin-top:0.2rem;display:flex;flex-wrap:wrap;gap:0.25rem}.landing-card-tag{font-size:0.7rem;padding:0.05rem 0.42rem;border-radius:999px;background:#f3f4f6;color:#4b5563}.landing-side-card{background:#f9fafb;border-radius:0.9rem;border:1px solid #e5e7eb;padding:0.7rem 0.8rem;display:flex;flex-direction:column;gap:0.45rem}.landing-side-card-title{font-size:0.85rem;font-weight:600;color:#111827}.landing-side-card-subtitle{font-size:0.78rem;color:#6b7280}.landing-side-list{list-style:none;padding:0;margin:0;font-size:0.78rem;color:#4b5563}.landing-side-list li{padding:0.22rem 0;border-bottom:1px dashed #e5e7eb}.landing-side-list li:last-child{border-bottom:none}.landing-cta-strip{margin-top:1.6rem;padding:0.85rem 0.9rem;border-radius:0.9rem;background:linear-gradient(90deg,#1d4ed8,#22c55e);color:#e5edff;display:flex;flex-wrap:wrap;align-items:center;gap:0.7rem;justify-content:space-between}.landing-cta-strip-left{display:flex;flex-direction:column;gap:0.18rem}.landing-cta-strip-title{font-size:0.9rem;font-weight:600}.landing-cta-strip-subtitle{font-size:0.78rem;color:#e0f2fe}.landing-cta-strip .btn{background:#ffffff;border-color:transparent;color:#1d4ed8;font-size:0.8rem}.landing-cta-strip .btn:hover{background:#eff6ff}.landing-chip-row{margin-top:0.3rem;display:flex;flex-wrap:wrap;gap:0.3rem;font-size:0.76rem}.landing-chip{padding:0.08rem 0.5rem;border-radius:999px;background:#f3f4f6;color:#4b5563}@media (max-width:960px){.landing-content-grid{grid-template-columns:minmax(0,1fr)}}@media (max-width:640px){.landing-hero{padding-top:1.4rem;padding-bottom:1.4rem}.landing-cta-strip{align-items:flex-start}}