*{margin:0;padding:0;box-sizing:border-box}@media (max-width: 920px){.hero-section{grid-template-columns:1fr}.hero-headline{font-size:30px}}:root{--primary-color: #2563eb;--primary-dark: #1d4ed8;--primary-light: #3b82f6;--secondary-color: #f59e0b;--error-color: #ef4444;--warning-color: #f59e0b;--success-color: #10b981;--text-dark: #111827;--text-light: #6b7280;--bg-light: #f9fafb;--bg-white: #ffffff;--border-color: rgba(209, 213, 219, .6);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .07), 0 1px 2px -1px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px -4px rgba(0, 0, 0, .12), 0 2px 6px -2px rgba(0, 0, 0, .06);--shadow-lg: 0 20px 48px -16px rgba(0, 0, 0, .18), 0 8px 20px -8px rgba(0, 0, 0, .08);--transition: all .2s cubic-bezier(.4, 0, .2, 1);--radius: 16px;--radius-sm: 12px;--ring: 0 0 0 3px rgba(37, 99, 235, .18)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(1200px 600px at 15% 18%,#3b82f642,#3b82f600 55%),radial-gradient(900px 420px at 82% 26%,#f59e0b2e,#f59e0b00 55%),linear-gradient(180deg,#f8fbff,#eef4ff 38%,#e7efff);min-height:100vh;color:var(--text-dark)}#root{min-height:100vh;padding:24px}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center}.auth-card{width:100%;max-width:920px;border-radius:var(--radius);border:1px solid var(--border-color);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-lg);overflow:hidden;display:grid;grid-template-columns:1.1fr 1fr}.auth-left{padding:40px;background:radial-gradient(700px 350px at 20% 0%,#3b82f647,#3b82f600 60%),linear-gradient(180deg,#ffffffa6,#ffffffe6);border-right:1px solid rgba(148,163,184,.25)}.auth-right{padding:40px}.brand{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:-.02em}.brand-mark{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,#3b82f6,#1d4ed8 55%,#f59e0b 120%);box-shadow:0 14px 30px -18px #1d4ed8bf}.brand-name{font-size:14px;color:var(--text-dark)}.brand-sub{font-size:12px;color:var(--text-light);margin-top:2px}.hero-title{margin-top:32px;font-size:34px;line-height:1.05;font-weight:900;letter-spacing:-.03em}.hero-title strong{color:var(--secondary-color)}.hero-desc{margin-top:14px;font-size:14px;color:var(--text-light);line-height:1.7;max-width:42ch}.hero-badges{margin-top:20px;display:flex;flex-wrap:wrap;gap:10px}.hero-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid rgba(148,163,184,.3);background:#ffffffb3;color:var(--text-dark);font-size:12px;font-weight:700}.container{width:100%;max-width:480px;background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:40px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-dark);font-size:14px}input[type=text],input[type=email],input[type=password]{width:100%;padding:12px 14px;border:1px solid rgba(148,163,184,.45);border-radius:12px;font-size:14px;color:var(--text-dark);transition:var(--transition);background-color:var(--bg-white)}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:44px}.password-toggle{position:absolute;top:50%;right:10px;transform:translateY(-50%);border:none;background:transparent;padding:6px;border-radius:6px;cursor:pointer;color:var(--text-light);display:flex;align-items:center;justify-content:center}.password-toggle:hover{background:var(--bg-light);color:var(--text-dark)}.password-toggle:disabled{opacity:.6;cursor:not-allowed}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus{outline:none;border-color:#3b82f6cc;box-shadow:var(--ring)}input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder{color:var(--text-light)}.btn{width:100%;padding:12px 16px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;text-align:center}.btn-primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px -8px #2563eb8c}.btn-primary:active{transform:translateY(0) scale(.98);box-shadow:0 2px 8px -4px #2563eb4d}.btn-secondary{background:transparent;color:var(--primary-dark);border:1px solid rgba(37,99,235,.4)}.btn-secondary:hover{background:#2563eb12;border-color:#2563ebb3;transform:translateY(-1px)}.btn-secondary:active{transform:translateY(0) scale(.98)}.btn-logout{background:transparent;color:var(--error-color);border:1px solid rgba(239,68,68,.35);width:auto;padding:10px 20px;margin-top:20px}.btn-logout:hover{background:#ef444412;border-color:#ef4444b3;transform:translateY(-1px);box-shadow:0 4px 12px #ef444426}.btn-logout:active{transform:translateY(0) scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}h1{font-size:32px;font-weight:700;margin-bottom:8px;color:var(--text-dark)}h2{font-size:28px;font-weight:700;margin-bottom:16px;color:var(--text-dark);background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 60%,var(--secondary-color) 140%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}p{font-size:14px;color:var(--text-light);line-height:1.6}a{color:var(--primary-color);text-decoration:none;font-weight:500;transition:var(--transition)}a:hover{color:var(--primary-dark);text-decoration:underline}.error-message{background-color:#fee2e2;color:var(--error-color);padding:12px 14px;border-radius:8px;margin-bottom:20px;border-left:4px solid var(--error-color);font-size:14px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes page-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:page-enter .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes badge-pulse{0%,to{opacity:1;box-shadow:0 0 #f59e0b59}50%{opacity:.85;box-shadow:0 0 0 4px #f59e0b00}}.badge-pulse{animation:badge-pulse 2s ease-in-out infinite}@keyframes modal-enter{0%{opacity:0;transform:scale(.95) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.auth-link{margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color);text-align:center;font-size:14px}.auth-link p{margin:0}.auth-link a{color:var(--primary-color);font-weight:600}.app-container{max-width:1040px;margin:0 auto;background:#ffffffdb;border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid rgba(148,163,184,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:28px;animation:slideUp .5s ease-out}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;padding:18px;border-radius:18px;border:1px solid rgba(148,163,184,.24);background:linear-gradient(135deg,#3b82f61a,#ffffffbf 40%,#f59e0b14)}.nav-title{display:flex;flex-direction:column;gap:2px}.nav-subtitle{color:var(--text-light);font-size:13px}.nav-actions{display:flex;gap:10px;align-items:center}.app-header h2{margin:0}.user-info{background:var(--bg-light);border-radius:8px;padding:24px;margin:20px 0;border:1px solid var(--border-color)}.user-info pre{background:var(--text-dark);color:#4ade80;padding:16px;border-radius:6px;overflow-x:auto;font-size:12px;line-height:1.5;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.card{background:#ffffffe6;border:1px solid rgba(209,213,219,.5);border-radius:16px;box-shadow:var(--shadow-sm);padding:20px;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),border-color .2s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#2563eb38}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.label{font-size:12px;font-weight:600;color:var(--text-light);margin-bottom:6px;text-transform:uppercase;letter-spacing:.02em}.value{font-size:14px;font-weight:600;color:var(--text-dark)}.pill-row{display:flex;flex-wrap:wrap;gap:8px}.pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600;background:#6366f11f;color:var(--primary-dark);border:1px solid rgba(99,102,241,.25)}.pill-admin{background:#10b9811f;color:#047857;border-color:#10b98140}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table thead th{text-align:left;font-size:12px;color:var(--text-light);padding:14px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-light)}.table tbody td{padding:14px 16px;border-bottom:1px solid var(--border-color);font-size:14px;color:var(--text-dark);vertical-align:middle}.table tbody tr{transition:background .15s ease}.table tbody tr:hover{background:#f9fafbe6}.muted{color:var(--text-light);font-size:14px;padding:16px}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid var(--border-color);color:var(--text-dark);background:var(--bg-white)}.badge-success{background:linear-gradient(135deg,#10b98124,#05966914);border-color:#10b9814d;color:#065f46;font-weight:600}.badge-error{background:linear-gradient(135deg,#ef444424,#dc262614);border-color:#ef44444d;color:#991b1b;font-weight:600}.badge-warning{background:linear-gradient(135deg,#f59e0b26,#d9770617);border-color:#f59e0b59;color:#78350f;font-weight:600}.section-title{font-size:18px;font-weight:600;margin-bottom:12px;color:var(--text-dark)}.info-banner{background:#3b82f61a;border:1px solid rgba(59,130,246,.22);color:var(--primary-dark);padding:12px 14px;border-radius:14px;margin-bottom:14px;font-size:14px}.admin-controls{display:flex;gap:14px;align-items:flex-end}.form-label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-dark);font-size:14px}.input,.select{width:100%;padding:12px 14px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;color:var(--text-dark);background-color:var(--bg-white);transition:var(--transition)}.input:focus,.select:focus{outline:none;border-color:#3b82f6cc;box-shadow:var(--ring)}.input-wrapper{position:relative}.input-wrapper .input{padding-right:44px}.input-action{position:absolute;top:50%;right:10px;transform:translateY(-50%);border:none;background:transparent;padding:6px;border-radius:6px;cursor:pointer;color:var(--text-light);display:flex;align-items:center;justify-content:center}.input-action:hover{background:var(--bg-light);color:var(--text-dark)}.input-action:disabled{opacity:.6;cursor:not-allowed}.field-error{margin-top:6px;font-size:12px;color:var(--error-color)}.pagination{display:flex;justify-content:flex-end;align-items:center;gap:12px;margin-top:14px}.pagination-info{color:var(--text-light);font-size:14px}.tab{display:inline-flex;align-items:center;height:38px;padding:0 14px;border-radius:999px;border:1px solid rgba(148,163,184,.35);background:#ffffffc7;color:var(--text-dark);text-decoration:none;font-weight:700;font-size:14px}.tab:hover{text-decoration:none;border-color:#3b82f68c}.tab-active{border-color:#3b82f68c;background:#3b82f61f;color:var(--primary-dark)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px}.page-header-title{display:flex;flex-direction:column;gap:6px}.page-header-actions{display:flex;align-items:center;gap:10px}.services-landing-inner{width:100%;max-width:920px;margin:0 auto}.services-landing-inner .page-header{justify-content:center}.services-landing-inner .page-header-title{align-items:center;text-align:center}.hero-section{display:grid;grid-template-columns:1.35fr 1fr;gap:18px;padding:22px;border-radius:22px;border:1px solid rgba(148,163,184,.26);background:linear-gradient(135deg,#3b82f624,#ffffffbd 44%,#f59e0b1a);box-shadow:var(--shadow-md);margin-bottom:18px}.hero-kicker{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid rgba(59,130,246,.25);background:#ffffffa6;color:var(--primary-dark);font-size:12px;font-weight:800;width:fit-content}.hero-headline{margin-top:12px;font-size:34px;line-height:1.07;font-weight:900;letter-spacing:-.03em}.hero-headline strong{color:var(--secondary-color)}.hero-subtext{margin-top:12px;color:var(--text-light);font-size:14px;line-height:1.7;max-width:64ch}.hero-actions{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px}.hero-actions .btn{width:auto}.hero-illustration{display:flex;align-items:center;justify-content:center;border-radius:20px;border:1px solid rgba(148,163,184,.22);background:#ffffffad;min-height:220px}.hero-illustration svg{width:min(320px,100%);height:auto}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1118278c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.modal{width:100%;max-width:520px;background:var(--bg-white);border-radius:16px;border:1px solid var(--border-color);box-shadow:var(--shadow-lg);padding:22px;animation:modal-enter .2s cubic-bezier(.4,0,.2,1) forwards}.modal-header{margin-bottom:10px}.modal-title{font-size:16px;font-weight:800;color:var(--text-dark)}.modal-body{color:var(--text-light);font-size:14px;margin-bottom:14px}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.btn-danger{background:linear-gradient(135deg,var(--error-color) 0%,#dc2626 100%);color:#fff}.btn-approve{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:8px 16px;width:auto;font-size:13px;font-weight:600;border-radius:8px}.btn-approve:hover{transform:translateY(-1px);box-shadow:0 6px 16px #10b98166}.btn-approve:active{transform:translateY(0) scale(.98)}.btn-reject{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:8px 16px;width:auto;font-size:13px;font-weight:600;border-radius:8px}.btn-reject:hover{transform:translateY(-1px);box-shadow:0 6px 16px #ef444466}.btn-reject:active{transform:translateY(0) scale(.98)}.service-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.service-card{position:relative;text-align:left;width:100%;background:#fff;border:1px solid var(--border-color);border-radius:20px;padding:26px;box-shadow:0 1px 4px #0000000d,0 1px 2px #00000008;cursor:pointer;display:flex;flex-direction:column;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s ease,border-color .25s ease,background .3s ease}.service-card:hover{transform:translateY(-4px)}.service-card--blue:hover{border-color:#2563eb66;box-shadow:0 16px 40px -8px #2563eb24,0 4px 10px #0000000d;background:linear-gradient(150deg,#2563eb08,#fff 55%)}.service-card--purple:hover{border-color:#7c3aed66;box-shadow:0 16px 40px -8px #7c3aed24,0 4px 10px #0000000d;background:linear-gradient(150deg,#7c3aed08,#fff 55%)}.service-card--teal:hover{border-color:#0d948866;box-shadow:0 16px 40px -8px #0d948824,0 4px 10px #0000000d;background:linear-gradient(150deg,#0d948808,#fff 55%)}.service-card--amber:hover{border-color:#d9770666;box-shadow:0 16px 40px -8px #d977061f,0 4px 10px #0000000d;background:linear-gradient(150deg,#d9770608,#fff 55%)}.service-card:hover .service-icon{transform:scale(1.07)}.service-card:hover .service-arrow{transform:translate(5px);color:var(--primary-color)}.service-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:20px;transition:transform .25s ease}.service-icon--blue{background:#2563eb1a;color:#2563eb}.service-icon--purple{background:#7c3aed1a;color:#7c3aed}.service-icon--teal{background:#0d94881a;color:#0d9488}.service-icon--amber{background:#f59e0b1a;color:#d97706}.service-card-body{flex:1}.service-title{font-size:16px;font-weight:700;color:var(--text-dark);margin-bottom:8px;letter-spacing:-.015em}.service-description{font-size:13.5px;color:var(--text-light);line-height:1.65}.service-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:22px;padding-top:16px;border-top:1px solid var(--border-color)}.service-role-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;border:1px solid;letter-spacing:.01em}.service-role-badge--free{background:#10b98117;border-color:#10b98147;color:#065f46}.service-role-badge--req{background:#2563eb14;border-color:#2563eb38;color:#1d4ed8}.service-arrow{display:flex;align-items:center;color:var(--text-light);transition:transform .22s ease,color .22s ease}.action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.action-card{text-align:left;width:100%;border:1px solid rgba(209,213,219,.5);background:#ffffffe6;border-radius:18px;padding:18px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .22s cubic-bezier(.4,0,.2,1),box-shadow .22s ease,border-color .22s ease}.action-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#2563eb66;background:#fffffff7}.code-block{margin-top:12px;background:#0f172a;color:#cbd5e1;padding:16px;border-radius:14px;overflow-x:auto;font-size:12.5px;line-height:1.65;font-family:Monaco,Menlo,Consolas,Ubuntu Mono,monospace;border:1px solid rgba(255,255,255,.06)}.code-block-wrap{position:relative}.code-block-copy{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:7px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#ffffffbf;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s ease}.code-block-copy:hover{background:#ffffff2e;color:#fff}.action-card-disabled{cursor:not-allowed;opacity:.75}.action-card-disabled:hover{transform:none;box-shadow:var(--shadow-sm);border-color:var(--border-color)}.action-title{font-size:15px;font-weight:800;color:var(--text-dark);margin-bottom:6px}.action-description{font-size:14px;color:var(--text-light);line-height:1.5}textarea.input{resize:vertical}.stat-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:18px}.stat-card{background:#ffffffeb;border:1px solid rgba(209,213,219,.5);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.stat-card__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);margin-bottom:6px}.stat-card__value{font-size:22px;font-weight:700;color:var(--text-dark);line-height:1}.stat-card__value--blue{color:var(--primary-color)}.stat-card__value--amber{color:#d97706}.stat-card__value--green{color:#059669}.result-success-banner{display:flex;align-items:center;gap:14px;padding:16px 18px;background:linear-gradient(135deg,#10b9811a,#0596690f);border:1px solid rgba(16,185,129,.25);border-radius:14px;margin-bottom:14px}.result-success-icon{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #10b98159}.result-success-text b{display:block;color:#065f46;font-size:14px;font-weight:700}.result-success-text span{font-size:13px;color:#047857}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:16px}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-light);font-size:14px}@media (max-width: 640px){.container,.app-container{padding:24px}.grid,.service-grid,.action-grid{grid-template-columns:1fr}h1{font-size:24px}h2{font-size:22px}.app-header{flex-direction:column;gap:16px;align-items:flex-start}}@media (max-width: 860px){.auth-card{grid-template-columns:1fr}.auth-left{border-right:none;border-bottom:1px solid rgba(148,163,184,.25)}}.cat-layout{display:flex;height:calc(100vh - 130px);background:#ffffffe6;border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md)}.cat-sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--border-color);background:#f8fafccc;display:flex;flex-direction:column}.cat-sidebar__header{display:flex;align-items:center;gap:8px;padding:18px 16px 12px;font-weight:600;font-size:14px;color:var(--text-dark);border-bottom:1px solid var(--border-color)}.cat-sidebar__nav{padding:10px 8px;display:flex;flex-direction:column;gap:2px}.cat-sidebar__item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;font-size:13px;color:var(--text-light);background:transparent;border:none;cursor:pointer;text-align:left;transition:var(--transition)}.cat-sidebar__item:hover{background:#3b82f60f;color:var(--text-dark)}.cat-sidebar__item--active{background:#3b82f61a;color:var(--primary-color);font-weight:600}.cat-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.cat-toolbar{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-color);background:#fffffff2;flex-shrink:0}.cat-tabs{display:flex;gap:4px;background:#f1f5f9cc;border-radius:10px;padding:3px}.cat-tab{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-light);background:transparent;border:none;cursor:pointer;transition:var(--transition)}.cat-tab:hover{color:var(--text-dark);background:#fff9}.cat-tab--active{background:#fff;color:var(--primary-color);font-weight:600;box-shadow:var(--shadow-sm)}.cat-search{position:relative;flex:1;max-width:320px}.cat-search__icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-light);pointer-events:none}.cat-search__input{width:100%;padding:8px 12px 8px 32px;border:1px solid rgba(148,163,184,.4);border-radius:10px;font-size:13px;color:var(--text-dark);background:#fff;outline:none;transition:var(--transition)}.cat-search__input:focus{border-color:#3b82f680;box-shadow:var(--ring)}.cat-back-btn{margin-left:auto;width:auto!important;padding:8px 14px;font-size:13px}.cat-content{flex:1;display:flex;overflow:hidden}.cat-list{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}.cat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-light);gap:8px;text-align:center}.cat-empty p{font-size:15px;font-weight:600;color:var(--text-dark)}.cat-empty span{font-size:13px}.cat-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:14px;cursor:pointer;transition:var(--transition);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.cat-card:hover{box-shadow:var(--shadow-md);border-color:#94a3b880}.cat-card--selected{border-color:#3b82f680;background:#3b82f608;box-shadow:0 0 0 2px #3b82f626}.cat-card__body{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.cat-card__icon{width:38px;height:38px;flex-shrink:0;border-radius:10px;display:flex;align-items:center;justify-content:center}.cat-card__icon--dataset{background:#3b82f61a;color:var(--primary-color)}.cat-card__icon--app{background:#6366f11a;color:#6366f1}.cat-card__content{flex:1;min-width:0}.cat-card__header{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}.cat-card__name{font-size:14px;font-weight:600;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-card__desc{font-size:12px;color:var(--text-light);line-height:1.5;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cat-card__meta{display:flex;flex-wrap:wrap;gap:10px;font-size:11px;color:var(--text-light)}.cat-card__meta-item{display:flex;align-items:center;gap:3px}.cat-card__capabilities{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.cat-card__footer{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.cat-card__actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.cat-btn-sm{padding:5px 12px;font-size:12px;border-radius:8px;font-weight:500;cursor:pointer;white-space:nowrap;transition:var(--transition);width:auto}.cat-btn-sm--primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;border:none}.cat-btn-sm--primary:hover{box-shadow:0 4px 12px #1d4ed859}.cat-btn-sm--outline{background:transparent;color:var(--primary-color);border:1px solid rgba(59,130,246,.5)}.cat-btn-sm--outline:hover{background:#3b82f60f}.cat-btn-sm--ghost{background:transparent;color:var(--text-light);border:1px solid var(--border-color)}.cat-btn-sm--ghost:hover{background:#0000000a;color:var(--text-dark)}.cat-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:500;white-space:nowrap}.cat-badge--selected{background:#3b82f61f;color:var(--primary-color);border:1px solid rgba(59,130,246,.25)}.cat-badge--version{background:#94a3b81f;color:var(--text-light);border:1px solid rgba(148,163,184,.25)}.cat-badge--provider{background:#6366f114;color:#6366f1;border:1px solid rgba(99,102,241,.2)}.cat-badge--category{background:#f59e0b1a;color:#b45309;border:1px solid rgba(245,158,11,.25)}.cat-badge--cap{background:#3b82f614;color:var(--primary-color);border:1px solid rgba(59,130,246,.18)}.cat-badge--type{background:#94a3b81a;color:var(--text-light);border:1px solid rgba(148,163,184,.2);font-family:monospace;font-size:10px}.cat-badge--tag{background:#10b98114;color:#047857;border:1px solid rgba(16,185,129,.2)}.cat-badge--warning{background:#f59e0b1a;color:#92400e;border:1px solid rgba(245,158,11,.25)}.cat-badge-group{display:flex;flex-wrap:wrap;gap:5px}.cat-detail-panel{width:420px;flex-shrink:0;border-left:1px solid var(--border-color);background:#fff;display:flex;flex-direction:column;overflow:hidden}.cat-detail-panel__header{padding:14px 16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.cat-detail-panel__title{display:flex;align-items:center;gap:10px}.cat-detail-panel__name{font-size:14px;font-weight:600;color:var(--text-dark)}.cat-detail-panel__provider{font-size:12px;color:var(--text-light);margin-top:1px}.cat-detail-panel__body{flex:1;overflow-y:auto;padding:16px}.cat-detail-panel__footer{padding:14px 16px;border-top:1px solid var(--border-color);flex-shrink:0}.cat-detail-section{margin-bottom:20px}.cat-detail-section__title{font-size:12px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;display:flex;align-items:center}.cat-detail-section__text{font-size:13px;color:var(--text-light);line-height:1.6}.cat-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.cat-stats-grid--3{grid-template-columns:repeat(3,1fr)}.cat-stat{background:#f8fafccc;border:1px solid var(--border-color);border-radius:10px;padding:10px 12px}.cat-stat--center{text-align:center;padding:12px}.cat-stat__icon{color:var(--text-light);margin-bottom:4px;display:flex;justify-content:center}.cat-stat__label{font-size:11px;color:var(--text-light);display:flex;align-items:center;gap:4px;margin-bottom:4px}.cat-stat__value{font-size:13px;font-weight:600;color:var(--text-dark)}.cat-stat__value--lg{font-size:15px;font-weight:700}.cat-detail-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:8px;font-size:13px}.cat-detail-row__label{display:flex;align-items:center;gap:4px;flex-shrink:0;min-width:110px;color:var(--text-light);font-size:12px}.cat-detail-row__value{color:var(--text-dark);font-weight:500}.cat-table-wrap{overflow-x:auto;border-radius:8px;border:1px solid var(--border-color)}.cat-table{width:100%;border-collapse:collapse;font-size:12px}.cat-table thead th{background:#f8fafce6;padding:8px 10px;text-align:left;font-weight:600;color:var(--text-light);font-size:11px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-color);white-space:nowrap}.cat-table tbody tr:not(:last-child) td{border-bottom:1px solid var(--border-color)}.cat-table tbody td{padding:8px 10px;color:var(--text-dark);vertical-align:top}.cat-code{font-family:monospace;background:#3b82f60f;color:var(--primary-color);padding:1px 5px;border-radius:4px;font-size:11px}.cat-icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:var(--text-light);transition:var(--transition);flex-shrink:0}.cat-icon-btn:hover{background:#0000000f;color:var(--text-dark)}.cat-summary{width:260px;flex-shrink:0;border-left:1px solid var(--border-color);background:#f8fafc99;padding:16px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.cat-summary__header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-dark);padding-bottom:10px;border-bottom:1px solid var(--border-color)}.cat-slot{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#ffffffb3;border:1px solid var(--border-color);border-radius:10px;transition:var(--transition)}.cat-slot--filled{background:#fffffff2;border-color:#3b82f64d}.cat-slot__icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#94a3b81f;color:var(--text-light);flex-shrink:0}.cat-slot--filled .cat-slot__icon{background:#10b9811f;color:#059669}.cat-slot__info{flex:1;min-width:0}.cat-slot__label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);font-weight:600;margin-bottom:2px}.cat-slot__value{font-size:12px;font-weight:600;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-slot__placeholder{font-size:12px;color:var(--text-light);font-style:italic}.cat-slot__clear{width:22px;height:22px;flex-shrink:0}.cat-status{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-light);padding:8px 10px;border-radius:8px;background:#94a3b814}.cat-status--ready{color:#059669;background:#10b98114}
