@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary:#0f1117;--bg-secondary:#1a1d27;--bg-card:#1e2130;--bg-card-hover:#252840;--bg-input:#252840;--border:#2d3148;--border-focus:#6366f1;--text-primary:#e8eaf0;--text-secondary:#9ca3b8;--text-muted:#6b7280;--accent:#6366f1;--accent-hover:#818cf8;--accent-bg:#6366f11f;--success:#22c55e;--success-bg:#22c55e1f;--warning:#f59e0b;--warning-bg:#f59e0b1f;--danger:#ef4444;--danger-bg:#ef44441f;--info:#3b82f6;--info-bg:#3b82f61f;--gradient-1:linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--gradient-2:linear-gradient(135deg, #3b82f6 0%, #6366f1 100%);--gradient-3:linear-gradient(135deg, #22c55e 0%, #16a34a 100%);--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--sidebar-width:260px;--header-height:64px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}.app-layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);padding-top:var(--header-height);flex:1}.page-content{max-width:1400px;padding:28px 32px}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:20px 24px;display:flex}.sidebar-logo .logo-icon{background:var(--gradient-1);border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;font-weight:800;display:flex}.sidebar-logo h1{color:var(--text-primary);letter-spacing:-.02em;font-size:16px;font-weight:700}.sidebar-logo p{color:var(--text-muted);margin-top:2px;font-size:11px}.sidebar-nav{flex:1;padding:16px 12px}.sidebar-section{margin-bottom:24px}.sidebar-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:8px;padding:0 12px;font-size:10px;font-weight:600}.sidebar-link{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.sidebar-link:hover{background:var(--bg-card);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-bg);color:var(--accent)}.sidebar-link .icon{text-align:center;flex-shrink:0;width:20px;font-size:18px}.sidebar-user{border-top:1px solid var(--border);padding:16px}.sidebar-user-info{align-items:center;gap:12px;margin-bottom:12px;display:flex}.sidebar-user-avatar{background:var(--gradient-2);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.sidebar-user-name{color:var(--text-primary);font-size:13px;font-weight:600}.sidebar-user-role{color:var(--text-muted);font-size:11px}.header{top:0;left:var(--sidebar-width);height:var(--header-height);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:90;background:#0f1117cc;align-items:center;padding:0 32px;display:flex;position:fixed;right:0}.header-title{letter-spacing:-.02em;font-size:18px;font-weight:700}.header-actions{align-items:center;gap:12px;margin-left:auto;display:flex}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all .3s}.card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.card-title{color:var(--text-primary);font-size:16px;font-weight:700}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all .3s;position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:3px 3px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card.accent:before{background:var(--gradient-1)}.stat-card.success:before{background:var(--gradient-3)}.stat-card.info:before{background:var(--gradient-2)}.stat-card.warning:before{background:linear-gradient(135deg,#f59e0b,#ef4444)}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:16px;font-size:20px;display:flex}.stat-icon.accent{background:var(--accent-bg);color:var(--accent)}.stat-icon.success{background:var(--success-bg);color:var(--success)}.stat-icon.info{background:var(--info-bg);color:var(--info)}.stat-icon.warning{background:var(--warning-bg);color:var(--warning)}.stat-value{letter-spacing:-.03em;margin-bottom:4px;font-size:28px;font-weight:800}.stat-label{color:var(--text-muted);font-size:13px;font-weight:500}.data-table-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th{background:var(--bg-secondary);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:14px 18px;font-size:12px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);padding:14px 18px;font-size:14px}.data-table tbody tr{cursor:pointer;transition:background .15s}.data-table tbody tr:hover{background:var(--bg-card-hover)}.data-table tbody tr:last-child td{border-bottom:none}.btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--gradient-1);color:#fff;border:none}.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 16px #6366f166}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);background:var(--accent-bg)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #0000}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:6px 14px;font-size:12px}.btn-icon{border-radius:var(--radius-sm);padding:8px}.form-group{margin-bottom:20px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-input,.form-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.form-input:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg);outline:none}.form-input::placeholder{color:var(--text-muted)}.search-box{position:relative}.search-box .search-icon{color:var(--text-muted);font-size:16px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-box .form-input{padding-left:42px}.badge{letter-spacing:.02em;border-radius:100px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-accent{background:var(--accent-bg);color:var(--accent)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:90%;max-width:560px;max-height:85vh;padding:32px;animation:.3s slideUp;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-title{font-size:20px;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px;font-size:20px;transition:all .2s}.modal-close:hover{color:var(--text-primary);background:var(--bg-input)}.modal-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.relationship-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.rel-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:14px;padding:16px;transition:all .2s;display:flex}.rel-card:hover{border-color:var(--accent);transform:translate(4px)}.rel-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:16px;font-weight:700;display:flex}.rel-avatar.male{background:var(--gradient-2)}.rel-avatar.female{background:linear-gradient(135deg,#ec4899,#f43f5e)}.rel-info h4{margin-bottom:2px;font-size:14px;font-weight:600}.rel-info p{color:var(--text-muted);font-size:12px}.rel-type{background:var(--accent-bg);color:var(--accent);border-radius:100px;flex-shrink:0;margin-left:auto;padding:3px 10px;font-size:11px;font-weight:600}.timeline{padding-left:32px;position:relative}.timeline:before{content:"";background:var(--border);width:2px;position:absolute;top:0;bottom:0;left:11px}.timeline-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:24px;padding:16px 20px;position:relative}.timeline-item:before{content:"";background:var(--accent);border:2px solid var(--bg-primary);border-radius:50%;width:10px;height:10px;position:absolute;top:20px;left:-27px}.timeline-item.create:before{background:var(--success)}.timeline-item.update:before{background:var(--warning)}.timeline-item.delete:before{background:var(--danger)}.timeline-date{color:var(--text-muted);margin-bottom:6px;font-size:11px}.timeline-content h4{margin-bottom:4px;font-size:14px;font-weight:600}.timeline-content p{color:var(--text-secondary);font-size:13px}.timeline-changes{background:var(--bg-secondary);border-radius:var(--radius-sm);margin-top:10px;padding:10px 14px;font-size:12px}.timeline-changes .change-row{gap:8px;padding:3px 0;display:flex}.change-field{color:var(--accent);min-width:100px;font-weight:600}.change-old{color:var(--danger);text-decoration:line-through}.change-new{color:var(--success)}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle at 30% 40%,#6366f114 0%,#0000 50%),radial-gradient(circle at 70% 60%,#8b5cf60f 0%,#0000 50%);width:200%;height:200%;animation:30s linear infinite rotate;position:absolute;top:-50%;left:-50%}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:48px;position:relative}.login-card h1{text-align:center;letter-spacing:-.03em;margin-bottom:8px;font-size:24px;font-weight:800}.login-card p{color:var(--text-muted);text-align:center;margin-bottom:32px;font-size:14px}.login-card .logo-wrapper{justify-content:center;margin-bottom:24px;display:flex}.login-card .logo-wrapper .logo-icon{background:var(--gradient-1);border-radius:var(--radius-lg);color:#fff;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;font-weight:800;display:flex}.form-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-sm);margin-bottom:16px;padding:10px 16px;font-size:13px}.login-switch{text-align:center;color:var(--text-muted);margin-top:20px;font-size:13px}.login-switch button{color:var(--accent);cursor:pointer;background:0 0;border:none;font-family:inherit;font-weight:600}.login-switch button:hover{color:var(--accent-hover)}.detail-header{align-items:flex-start;gap:24px;margin-bottom:32px;display:flex}.detail-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:28px;display:flex}.detail-info h2{letter-spacing:-.02em;margin-bottom:4px;font-size:22px;font-weight:800}.detail-info p{color:var(--text-muted);font-size:14px}.detail-meta{gap:24px;margin-top:8px;display:flex}.detail-meta span{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.section-title{align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.filters-bar{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:24px;display:flex}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600}.filter-group .form-input,.filter-group .form-select{min-width:160px}.tabs{background:var(--bg-secondary);border-radius:var(--radius-md);gap:4px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.tab{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:8px 20px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--accent-bg);color:var(--accent)}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state .icon{opacity:.4;margin-bottom:16px;font-size:48px}.empty-state h3{color:var(--text-secondary);margin-bottom:8px;font-size:16px;font-weight:600}.empty-state p{font-size:13px}.spinner{justify-content:center;align-items:center;padding:60px;display:flex}.spinner:after{content:"";border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.page-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.page-title{letter-spacing:-.03em;font-size:24px;font-weight:800}.page-subtitle{color:var(--text-muted);margin-top:4px;font-size:14px}.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:300;align-items:center;gap:10px;padding:14px 20px;font-size:14px;animation:.3s slideUp;display:flex;position:fixed;bottom:24px;right:24px}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.personal-info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.info-item{background:var(--bg-secondary);border-radius:var(--radius-sm);padding:14px}.info-item label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px;font-size:11px;font-weight:600;display:block}.info-item span{color:var(--text-primary);font-size:15px;font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUpModal{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes rotate{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.user-role-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:4px 10px;font-family:inherit;font-size:12px}@media (width<=768px){.sidebar{transition:transform .3s cubic-bezier(.4,0,.2,1);transform:translate(-100%);box-shadow:4px 0 24px #00000080}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.header{padding:0 16px;left:0}.header-title{font-size:16px}.page-header{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:20px}.page-content{padding:16px 16px 60px}.page-title{font-size:20px}.stats-grid{grid-template-columns:1fr;gap:16px}.filters-bar{flex-direction:column;align-items:stretch;gap:12px}.filter-group .form-input,.filter-group .form-select{min-width:100%;height:44px}.btn{justify-content:center;width:100%;min-height:44px}.btn-sm{flex:1;width:auto;min-height:36px}.modal-overlay{align-items:flex-end}.modal{border:none;border-top:1px solid var(--border);border-radius:24px 24px 0 0;width:100%;max-width:100%;max-height:85vh;margin:0;padding:24px 20px 40px;animation:.3s cubic-bezier(.4,0,.2,1) slideUpModal}.modal-actions{flex-direction:column;gap:12px}.data-table-wrapper{-webkit-overflow-scrolling:touch;border-left:none;border-right:none;border-radius:0;margin:0 -16px;overflow-x:auto}.data-table th,.data-table td{white-space:nowrap;padding:14px 16px}.detail-header{text-align:center;flex-direction:column;align-items:center;gap:16px}.detail-meta{flex-wrap:wrap;justify-content:center;gap:12px}.personal-info-grid{grid-template-columns:1fr;gap:12px}.card{padding:16px}.timeline{padding-left:20px}.timeline:before{left:4px}.timeline-item{padding:16px}.timeline-item:before{width:10px;height:10px;left:-22px}}.sidebar-overlay{display:none}.menu-toggle{color:var(--text-primary);cursor:pointer;background:0 0;border:none;margin-right:16px;padding:4px;font-size:24px;display:none}@media (width<=768px){.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:95;background:#00000080;animation:.2s fadeIn;display:block;position:fixed;inset:0}.menu-toggle{align-items:center;display:flex}}@media print{body{color:#000!important;background-color:#fff!important}.sidebar,.page-header button,.modal-actions,.hidden-print,.header{display:none!important}.main-content{width:100%!important;margin:0!important;padding:0!important}.app-layout{display:block!important}.page-content{max-width:none!important;padding:20px!important}.tab-buttons{display:none!important}.data-table-wrapper{background:0 0!important;border:none!important}.data-table th,.data-table td{color:#000!important;border-color:#ddd!important}.stat-card{break-inside:avoid;color:#000!important;box-shadow:none!important;background:#fff!important;border:1px solid #ddd!important}.detail-card{background:0 0!important;border:1px solid #000!important}.info-item label{color:#444!important}*{box-shadow:none!important;text-shadow:none!important}@page{margin:1cm}}
