:root{--color-primary: #1565c0;--color-primary-light:#1976d2;--color-primary-dark: #0d47a1;--color-accent: #0097a7;--sidebar-bg: #0f172a;--sidebar-bg-hover: rgba(255,255,255,.08);--sidebar-text: rgba(255,255,255,.75);--sidebar-text-active:#ffffff;--sidebar-width: 260px;--bg-app: #f1f5f9;--bg-card: #ffffff;--bg-muted: #f8fafc;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border-color: #e2e8f0;--border-radius-sm: 8px;--border-radius-md: 12px;--border-radius-lg: 16px;--border-radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 10px 30px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.06);--color-success: #16a34a;--color-success-bg: #f0fdf4;--color-warning: #d97706;--color-warning-bg: #fffbeb;--color-error: #dc2626;--color-error-bg: #fef2f2;--color-info: #0369a1;--color-info-bg: #f0f9ff;--font-family: "Inter", "Roboto", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--transition-fast: .15s ease;--transition-md: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-family);background:var(--bg-app);color:var(--text-primary);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}h1{font-size:var(--font-size-3xl);font-weight:700;color:var(--text-primary);line-height:1.2}h2{font-size:var(--font-size-2xl);font-weight:600;color:var(--text-primary)}h3{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}h4{font-size:var(--font-size-lg);font-weight:500;color:var(--text-primary)}p{color:var(--text-secondary);line-height:1.6}.mat-mdc-form-field{width:100%}.mat-mdc-card{border-radius:var(--border-radius-lg)!important;box-shadow:var(--shadow-sm)!important;border:1px solid var(--border-color)!important}.mat-mdc-button,.mat-mdc-raised-button,.mat-mdc-outlined-button,.mat-mdc-flat-button{border-radius:var(--border-radius-sm)!important;font-weight:500!important;letter-spacing:.01em!important}.mat-mdc-tab-group{border-radius:var(--border-radius-lg)!important;overflow:hidden;box-shadow:var(--shadow-sm)!important;border:1px solid var(--border-color)!important}.mat-mdc-snack-bar-container{border-radius:var(--border-radius-md)!important}.snack-ok .mdc-snackbar__surface{background:#0f172a!important}.snack-error .mdc-snackbar__surface{background:var(--color-error)!important}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.02em}.badge.installed,.badge.active,.badge.publish{background:var(--color-success-bg);color:var(--color-success)}.badge.pending,.badge.draft{background:var(--color-warning-bg);color:var(--color-warning)}.badge.error,.badge.inactive{background:var(--color-error-bg);color:var(--color-error)}.badge.installing,.badge.info{background:var(--color-info-bg);color:var(--color-info)}.loading-center{display:flex;justify-content:center;align-items:center;padding:60px}.empty-state{text-align:center;padding:80px 40px;background:var(--bg-card);border-radius:var(--border-radius-lg);border:1px solid var(--border-color)}.empty-state mat-icon{font-size:3.5rem;width:3.5rem;height:3.5rem;color:#cbd5e1}.empty-state h3{font-size:var(--font-size-xl);color:var(--text-secondary);margin:16px 0 8px}.empty-state p{color:var(--text-muted);margin-bottom:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:600px){.form-row{grid-template-columns:1fr}}.form-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.page-wrapper{max-width:1200px;margin:0 auto;padding:32px 24px}@media(max-width:768px){.page-wrapper{padding:16px}}.app-layout{display:flex;min-height:100vh}.app-sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);position:fixed;height:100vh;display:flex;flex-direction:column;z-index:200;transition:transform var(--transition-md)}@media(max-width:768px){.app-sidebar{transform:translate(-100%)}.app-sidebar.open{transform:translate(0)}}.app-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}@media(max-width:768px){.app-content{margin-left:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in-up{animation:fadeInUp .35s ease forwards}.fade-in{animation:fadeIn .25s ease forwards}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:199}@media(max-width:768px){.sidebar-overlay.visible{display:block}}.mobile-header{display:none;align-items:center;gap:12px;padding:16px;background:var(--sidebar-bg);color:#fff;position:sticky;top:0;z-index:100}@media(max-width:768px){.mobile-header{display:flex}}.mobile-header span{font-size:var(--font-size-lg);font-weight:700}.snack-ok .mdc-snackbar__surface{background:#0f172a!important;border-left:4px solid #16a34a!important}.snack-error .mdc-snackbar__surface{background:#0f172a!important;border-left:4px solid #dc2626!important}.snack-info .mdc-snackbar__surface{background:#0f172a!important;border-left:4px solid #1976d2!important}.mat-mdc-snack-bar-container{border-radius:10px!important;box-shadow:0 8px 24px #0003!important}.mat-mdc-dialog-container .mdc-dialog__surface{border-radius:20px!important;box-shadow:0 24px 64px #00000026!important}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.slide-in-right{animation:slideInRight .3s ease forwards}.scale-in{animation:scaleIn .25s ease forwards}.stagger-1{animation-delay:60ms}.stagger-2{animation-delay:.12s}.stagger-3{animation-delay:.18s}.stagger-4{animation-delay:.24s}.stagger-5{animation-delay:.3s}.stagger-6{animation-delay:.36s}.stagger-7{animation-delay:.42s}.stagger-8{animation-delay:.48s}.stagger-9{animation-delay:.54s}.stagger-10{animation-delay:.6s}.stagger-11{animation-delay:.66s}.stagger-12{animation-delay:.72s}.mat-mdc-tooltip{font-size:.75rem!important;border-radius:6px!important}.loading-overlay{position:absolute;inset:0;background:#fffc;display:flex;align-items:center;justify-content:center;border-radius:inherit;z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.search-bar{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:8px 14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-bar:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #1565c01a}.search-bar mat-icon{color:var(--text-muted);font-size:1.1rem;width:1.1rem;height:1.1rem}.search-bar input{border:none;outline:none;background:transparent;font-size:var(--font-size-sm);color:var(--text-primary);width:220px;font-family:var(--font-family)}.search-bar input::placeholder{color:var(--text-muted)}@media(max-width:480px){.search-bar input{width:140px}}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:24px;flex-wrap:wrap}.page-btn{width:36px;height:36px;border-radius:var(--border-radius-sm)!important;font-size:var(--font-size-sm)!important;min-width:unset!important}.page-btn.active{background:var(--color-primary)!important;color:#fff!important}
