*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #14b8a6;--primary-dark: #0d9488;--primary-light: #2dd4bf;--primary-ultra-light: #ccfbf1;--secondary: #64748b;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--info: #3b82f6;--white: #ffffff;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--sidebar-width: 280px;--sidebar-footer-max-height: 250px;--header-height: 64px;--border-radius: 12px;--border-radius-sm: 8px;--border-radius-lg: 16px;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition: all .3s cubic-bezier(.4, 0, .2, 1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.6;color:var(--gray-900);background:var(--gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--white);border-right:1px solid var(--gray-200);display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:1000;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 20px #00000026}.sidebar.open{transform:translate(0)}.sidebar-header{padding:1rem 1.25rem;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;min-height:64px;background:linear-gradient(135deg,var(--white) 0%,var(--gray-50) 100%);flex-shrink:0}.logo{font-size:1.25rem;font-weight:800;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;letter-spacing:-.02em}.mobile-menu-close{display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;width:36px;height:36px;border-radius:var(--border-radius-sm);font-size:1.25rem;cursor:pointer;color:var(--gray-700);transition:var(--transition);flex-shrink:0}.mobile-menu-close:hover{background:var(--gray-200);color:var(--gray-900);transform:scale(1.05)}.mobile-menu-close:active{transform:scale(.95)}.sidebar-nav{flex:1;padding:1rem;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:9999px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--gray-700);text-decoration:none;border-radius:var(--border-radius-sm);margin-bottom:.375rem;transition:var(--transition);font-weight:500;font-size:.9375rem;position:relative;overflow:hidden}.nav-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary);transform:scaleY(0);transition:transform .2s ease;border-radius:0 var(--border-radius-sm) var(--border-radius-sm) 0}.nav-item:hover{background:var(--gray-100);color:var(--primary);padding-left:1.25rem}.nav-item:hover:before{transform:scaleY(1)}.nav-item.active{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--white);font-weight:600;box-shadow:0 4px 12px #14b8a64d;padding-left:1.25rem}.nav-item.active:before{transform:scaleY(1);background:var(--white)}.nav-icon{font-size:1.25rem;flex-shrink:0}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--gray-200);background:var(--gray-50);flex-shrink:0}.user-info{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem;background:var(--white);border-radius:var(--border-radius-sm);box-shadow:var(--shadow-sm);transition:var(--transition)}.user-info:hover{box-shadow:var(--shadow-md)}.user-info-roles{max-height:150px;overflow-y:auto;margin:.5rem 0;-webkit-overflow-scrolling:touch}.user-info-roles::-webkit-scrollbar{width:4px}.user-info-roles::-webkit-scrollbar-track{background:transparent}.user-info-roles::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:9999px}.user-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0;box-shadow:0 2px 8px #14b8a64d}.user-details{flex:1;min-width:0}.user-email{font-size:.875rem;font-weight:600;color:var(--gray-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;margin-bottom:.25rem;line-height:1.3}.user-role{font-size:.75rem;color:var(--gray-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;line-height:1.3}.mobile-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--white);border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:50}.mobile-menu-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--gray-700);padding:var(--spacing-xs);transition:var(--transition)}.mobile-menu-btn:hover{color:var(--gray-900)}.main-content{flex:1;min-height:100vh;width:100%}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:90;opacity:0;pointer-events:none;transition:opacity .3s ease}.sidebar-overlay.active{opacity:1;pointer-events:auto}@media (min-width: 640px){.sidebar-header{padding:1.25rem 1.5rem}.logo{font-size:1.375rem}.nav-item{font-size:1rem;padding:.875rem 1.125rem}.nav-item:hover,.nav-item.active{padding-left:1.375rem}.user-avatar{width:44px;height:44px;font-size:1.0625rem}.user-email{font-size:.9375rem}}@media (min-width: 768px){.sidebar{width:260px}.sidebar-header{padding:1.5rem 1.75rem}.logo{font-size:1.5rem}.sidebar-nav{padding:1.25rem}.nav-item{gap:1rem;padding:1rem 1.25rem;font-size:1rem;margin-bottom:.5rem}.nav-item:hover,.nav-item.active{padding-left:1.5rem}.nav-icon{font-size:1.375rem}.sidebar-footer{padding:1.5rem 1.75rem}.user-info{padding:1rem}.user-info-roles{max-height:200px}.user-avatar{width:46px;height:46px;font-size:1.125rem}.user-email{font-size:1rem}.user-role{font-size:.8125rem}}@media (min-width: 1024px){.sidebar{transform:translate(0);width:var(--sidebar-width);box-shadow:none;border-right:1px solid var(--gray-200)}.sidebar-header{padding:1.75rem 2rem}.logo{font-size:1.625rem}.mobile-menu-close{display:none}.sidebar-nav{padding:1.5rem}.nav-item{padding:1rem 1.5rem;font-size:1.0625rem}.nav-item:hover,.nav-item.active{padding-left:1.75rem}.user-info-roles{max-height:220px}.user-avatar{width:48px;height:48px;font-size:1.25rem}.user-email{font-size:.875rem}.user-role{font-size:.75rem}.mobile-header{display:none}.main-content{margin-left:var(--sidebar-width)}.sidebar-overlay{display:none}}@media (min-width: 1280px){.sidebar{width:300px}.main-content{margin-left:300px}.sidebar-header{padding:2rem 2.25rem}.logo{font-size:1.75rem}.nav-item{font-size:1.125rem;padding:1.125rem 1.75rem}.nav-item:hover,.nav-item.active{padding-left:2rem}.user-avatar{width:50px;height:50px;font-size:1.375rem}}@media (min-width: 1536px){.sidebar{width:320px}.main-content{margin-left:320px}.nav-item{font-size:1.1875rem}.sidebar-footer{padding:2rem 2.25rem}}.page-container{padding:var(--spacing-md);max-width:1400px;margin:0 auto;width:100%}@media (min-width: 768px){.page-container{padding:var(--spacing-lg)}}@media (min-width: 1024px){.page-container{padding:var(--spacing-xl);max-width:1200px}}@media (min-width: 1280px){.page-container{max-width:1280px}}@media (min-width: 1536px){.page-container{max-width:1400px;padding:var(--spacing-2xl) var(--spacing-xl)}}.breadcrumb{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);font-size:.75rem;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.breadcrumb::-webkit-scrollbar{display:none}.breadcrumb-item a{color:var(--gray-600);text-decoration:none;transition:var(--transition)}.breadcrumb-item a:hover{color:var(--primary)}.breadcrumb-item .current{color:var(--gray-900);font-weight:600}.breadcrumb .separator{color:var(--gray-400);margin:0 var(--spacing-xs)}@media (min-width: 768px){.breadcrumb{gap:var(--spacing-sm);font-size:.8125rem}}@media (min-width: 1024px){.breadcrumb{margin-bottom:var(--spacing-lg);font-size:.875rem}}.page-header{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.page-header h1{font-size:1.5rem;font-weight:700;color:var(--gray-900);line-height:1.2}.page-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);width:100%}.page-actions .select,.page-actions .btn{width:100%}@media (min-width: 640px){.page-header h1{font-size:1.75rem}.page-actions{flex-direction:row;flex-wrap:wrap}.page-actions .select,.page-actions .btn{width:auto;flex:1;min-width:150px}}@media (min-width: 768px){.page-header h1{font-size:1.875rem}}@media (min-width: 1024px){.page-header{flex-direction:row;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);gap:var(--spacing-lg)}.page-header h1{font-size:2rem}.page-actions{width:auto;gap:var(--spacing-md);flex-wrap:nowrap}.page-actions .select,.page-actions .btn{flex:0 1 auto}}@media (min-width: 1280px){.page-header h1{font-size:2.25rem}}.card{background:var(--white);border-radius:var(--border-radius);box-shadow:var(--shadow);padding:var(--spacing-md);transition:var(--transition)}.card-hover{cursor:pointer}.card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.card-icon{font-size:2rem;margin-bottom:var(--spacing-sm)}.card h3{font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--gray-900)}.card p{color:var(--gray-600);font-size:.875rem;line-height:1.5}.card-footer{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--gray-200)}@media (min-width: 640px){.card-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}}@media (min-width: 768px){.card{padding:var(--spacing-lg)}.card-icon{font-size:2.25rem}}@media (min-width: 1024px){.card{padding:var(--spacing-xl)}.card-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.card-icon{font-size:2.5rem;margin-bottom:var(--spacing-md)}.card h3{font-size:1.25rem}.card-footer{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}}@media (min-width: 1280px){.card-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:.5rem 1rem;font-size:.8125rem;font-weight:600;border-radius:var(--border-radius-sm);border:none;cursor:pointer;transition:var(--transition);text-decoration:none;white-space:nowrap;width:auto}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--white)}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-danger{background:var(--danger);color:var(--white)}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-logout{width:100%!important;background:var(--gray-100);color:var(--gray-700)}.btn-logout:hover{background:var(--gray-200)}.btn-small{padding:.375rem .75rem;font-size:.75rem}.btn-block{width:100%}@media (min-width: 640px){.btn{width:auto;gap:var(--spacing-sm);padding:.625rem 1.25rem;font-size:.875rem}.btn-small{font-size:.8125rem}}@media (min-width: 1024px){.btn{padding:.6875rem 1.5rem}}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:600;color:var(--gray-700);font-size:.8125rem}.form-control,input[type=text],input[type=email],input[type=password],input[type=url],input[type=number],textarea,select,.select{width:100%;padding:.625rem .875rem;border:1px solid var(--gray-300);border-radius:var(--border-radius-sm);font-size:.875rem;color:var(--gray-900);background:var(--white);transition:var(--transition)}.form-control:focus,input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #14b8a61a}textarea{resize:vertical;font-family:inherit;min-height:100px}.form-actions{display:flex;flex-direction:column-reverse;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.form-actions .btn{width:100%}.file-input-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.file-input-group input{flex:1}@media (min-width: 640px){.form-actions{flex-direction:row;justify-content:flex-end;gap:var(--spacing-md)}.form-actions .btn{width:auto}.file-input-group{flex-direction:row}}@media (min-width: 768px){.form-group{margin-bottom:var(--spacing-lg)}.form-group label{margin-bottom:var(--spacing-sm);font-size:.875rem}textarea{min-height:120px}}@media (min-width: 1024px){.form-actions{margin-top:var(--spacing-xl)}textarea{min-height:150px}}.table-container{background:var(--white);border-radius:var(--border-radius);box-shadow:var(--shadow);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}.table{border-collapse:collapse;width:max-content;min-width:100%;font-size:.8125rem}.table thead{background:var(--gray-50)}.table th{padding:1.5rem 1rem;text-align:left;font-weight:600;font-size:.7rem;text-transform:uppercase;color:var(--gray-600);letter-spacing:.05em;white-space:nowrap}.table td{padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--gray-200);font-size:.8125rem;max-width:400px}.table tbody tr{transition:var(--transition)}.table tbody tr:hover{background:var(--gray-50)}.actions-column{text-align:right;white-space:nowrap}td img.img-small{width:40px;height:40px}td img.img-medium{width:60px;height:60px}td img.img-large{width:70px;height:70px}td img.img-small:hover{filter:grayscale(1)}code.code{flex:1;font-family:Courier New,monospace;font-size:.75rem;background:var(--gray-100);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);word-break:break-all}.actions-column .btn{width:auto!important;margin-left:var(--spacing-xs)}@media (min-width: 768px){.table th{padding:var(--spacing-md);font-size:.75rem}.table td{padding:var(--spacing-md)}}@media (min-width: 1024px){.table{font-size:.875rem}.table th{padding:1rem 1.5rem}.table td{padding:var(--spacing-md) var(--spacing-lg);font-size:.875rem}code.code{font-size:.8125rem}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:var(--white);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;width:100%;animation:modalIn .3s ease-out}@keyframes modalIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-medium{max-width:500px}.modal-large{max-width:100%}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--gray-200)}.modal-header h2{font-size:1.125rem;font-weight:600;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--gray-500);cursor:pointer;transition:var(--transition);padding:var(--spacing-xs);flex-shrink:0}.modal-close:hover{color:var(--gray-900)}.modal-body{padding:var(--spacing-md)}.modal-actions{display:flex;flex-direction:column-reverse;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.modal-actions .btn{width:100%}@media (min-width: 640px){.modal-overlay{padding:var(--spacing-lg)}.modal-content{border-radius:var(--border-radius-lg)}.modal-actions{flex-direction:row;justify-content:flex-end;gap:var(--spacing-md)}.modal-actions .btn{width:auto}}@media (min-width: 768px){.modal-large{max-width:700px}.modal-header{padding:var(--spacing-lg)}.modal-header h2{font-size:1.25rem}.modal-body{padding:var(--spacing-lg)}.modal-actions{margin-top:var(--spacing-lg)}}@media (min-width: 1024px){.modal-large{max-width:800px}.modal-header,.modal-body{padding:var(--spacing-xl)}}@media (min-width: 1280px){.modal-large{max-width:900px}}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;border-radius:9999px;background:var(--gray-100);color:var(--gray-700)}.badge-secondary{background:var(--secondary);color:var(--white)}.badge-success{background:var(--success);color:var(--white)}.badge-danger{background:var(--danger);color:var(--white)}.badge-warning{background:var(--warning);color:var(--white)}.alert{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-md);font-size:.8125rem}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#ccfbf1;color:#0f766e;border:1px solid #99f6e4}@media (min-width: 768px){.alert{padding:var(--spacing-md) var(--spacing-lg);font-size:.875rem}}@media (min-width: 1024px){.alert{margin-bottom:var(--spacing-lg)}}.text-muted{color:var(--gray-500)}.link{color:var(--primary);text-decoration:none;font-weight:600;transition:var(--transition)}.link:hover{color:var(--primary-dark);text-decoration:underline}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--gray-500);font-size:.875rem}.loading-container{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-spinner{width:32px;height:32px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (min-width: 768px){.loading-spinner{width:36px;height:36px}}@media (min-width: 1024px){.empty-state{padding:var(--spacing-2xl)}.loading-spinner{width:40px;height:40px;border-width:4px}}.code-snippet{font-family:Courier New,monospace;font-size:.75rem;background:var(--gray-100);padding:.25rem .5rem;border-radius:.25rem;color:var(--gray-900)}.code-block{display:flex;flex-direction:column;gap:var(--spacing-sm);margin:var(--spacing-sm) 0}.code-block code{flex:1;font-family:Courier New,monospace;font-size:.75rem;background:var(--gray-100);padding:var(--spacing-sm);border-radius:var(--border-radius-sm);overflow-x:auto}@media (min-width: 640px){.code-block{flex-direction:row;align-items:center;gap:var(--spacing-md);margin:var(--spacing-md) 0}}@media (min-width: 768px){.code-snippet{font-size:.8125rem}.code-block code{font-size:.8125rem;padding:var(--spacing-sm) var(--spacing-md)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0a0e27;padding:var(--spacing-md);position:relative;overflow:hidden}.perspective-grid{position:absolute;width:100%;height:100%;background-image:linear-gradient(rgba(20,184,166,.15) 2px,transparent 2px),linear-gradient(90deg,rgba(20,184,166,.15) 2px,transparent 2px);background-size:100px 100px;transform:perspective(500px) rotateX(60deg);transform-origin:center bottom;animation:gridScroll 20s linear infinite}@keyframes gridScroll{0%{background-position:0 0}to{background-position:0 100px}}.particle-field{position:absolute;width:100%;height:100%}.field-particle{position:absolute;width:3px;height:3px;background:#14b8a6;border-radius:50%;box-shadow:0 0 8px #14b8a6;animation:particleMove 20s linear infinite}.field-particle:nth-child(1){left:15%;top:10%;animation-delay:0s}.field-particle:nth-child(2){left:35%;top:25%;animation-delay:3s}.field-particle:nth-child(3){left:55%;top:15%;animation-delay:6s}.field-particle:nth-child(4){left:75%;top:30%;animation-delay:9s}.field-particle:nth-child(5){left:25%;bottom:20%;animation-delay:2s}.field-particle:nth-child(6){left:65%;bottom:25%;animation-delay:5s}.field-particle:nth-child(7){left:85%;bottom:15%;animation-delay:8s}@keyframes particleMove{0%,to{transform:translate(0);opacity:.3}25%{transform:translate(30px,-30px);opacity:.8}50%{transform:translate(-20px,20px);opacity:1}75%{transform:translate(25px,15px);opacity:.6}}.glow-orb{position:absolute;border-radius:50%;filter:blur(80px);animation:orbPulse 8s ease-in-out infinite}.login-container{width:100%;max-width:440px;position:relative;z-index:10}.login-card{background:#ffffff0a;-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:0 20px 60px #0006,inset 0 1px #ffffff1a;padding:var(--spacing-2xl);position:relative;transition:transform .3s ease,box-shadow .3s ease}.login-card:hover{transform:translateY(-5px);box-shadow:0 30px 80px #00000080,inset 0 1px #ffffff26}.login-logos{display:flex;justify-content:center;align-items:center;gap:20px;margin-bottom:20px;flex-wrap:wrap}.login-logo{display:flex;justify-content:center;align-items:center;background:transparent;padding:0;border-radius:0}.login-logo img{height:60px;width:auto;background:transparent;display:block;object-fit:contain;filter:none;transition:transform .3s ease}.login-logo:hover img{transform:scale(1.05)}.login-title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:var(--spacing-sm);background:linear-gradient(135deg,#fff,#14b8a6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px}.login-subtitle{text-align:center;color:#fff9;font-size:.938rem;margin-bottom:var(--spacing-xl);font-weight:400}.login-form{margin-top:var(--spacing-lg)}.login-btn{width:100%;padding:15px 24px;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:12px;color:#fff;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #14b8a64d;position:relative;overflow:hidden}.login-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.login-btn :hover{transform:translateY(-2px);box-shadow:0 8px 30px #14b8a666}.login-btn:hover:before{left:100%}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-btn span{position:relative;z-index:1}.login-form .form-group{margin-bottom:1.5rem}.login-form .form-group label{display:block;margin-bottom:.75rem;color:#fffc;font-weight:600;font-size:.875rem;letter-spacing:.3px;transition:color .3s ease}.login-form .form-group:focus-within label{color:#14b8a6}.login-form .form-group input{width:100%;padding:15px 18px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:1rem;transition:all .3s ease;outline:none;font-weight:400}.login-form .form-group input::placeholder{color:#ffffff4d}.login-form .form-group input:hover{background:#ffffff12;border-color:#ffffff26}.login-form .form-group input:focus{background:#ffffff14;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a626}@media (min-width: 640px){.login-page{padding:var(--spacing-lg)}.login-card{border-radius:var(--border-radius-lg);padding:var(--spacing-xl)}.login-title{font-size:1.75rem}}@media (min-width: 768px){.login-title{font-size:1.875rem}.login-subtitle{margin-bottom:var(--spacing-xl)}.login-form{margin-top:var(--spacing-lg)}}@media (min-width: 1024px){.login-card{padding:var(--spacing-2xl)}}.rich-editor{border:1px solid var(--gray-300);border-radius:var(--border-radius-sm);overflow:hidden}.rich-editor-toolbar{display:flex;gap:.25rem;padding:var(--spacing-xs);background:var(--gray-50);border-bottom:1px solid var(--gray-300);flex-wrap:wrap;overflow-x:auto}.rich-editor-toolbar button{padding:.375rem .625rem;border:1px solid var(--gray-300);background:var(--white);border-radius:.25rem;cursor:pointer;font-size:.8125rem;transition:var(--transition);white-space:nowrap}.rich-editor-toolbar button:hover{background:var(--gray-100)}.toolbar-divider{width:1px;background:var(--gray-300);margin:0 .25rem}.rich-editor-content{padding:var(--spacing-sm);min-height:150px;outline:none;font-size:.875rem}@media (min-width: 640px){.rich-editor-toolbar{padding:var(--spacing-sm)}.rich-editor-toolbar button{padding:.375rem .75rem;font-size:.875rem}.rich-editor-content{padding:var(--spacing-md);min-height:200px}}@media (min-width: 1024px){.rich-editor-content{min-height:250px}}.file-picker-actions{margin-bottom:var(--spacing-md)}.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--spacing-sm)}.file-card{padding:var(--spacing-sm);border:2px solid var(--gray-200);border-radius:var(--border-radius-sm);text-align:center;cursor:pointer;transition:var(--transition)}.file-card:hover{border-color:var(--primary);background:var(--gray-50);transform:translateY(-2px)}.file-icon{font-size:1.75rem;margin-bottom:var(--spacing-xs)}.file-picker-image{align-content:center}.file-picker-image img{display:block;width:80px;height:60px;margin:auto}.file-name{font-size:.7rem;color:var(--gray-700);word-break:break-all;margin-bottom:var(--spacing-xs)}.file-size{font-size:.65rem;color:var(--gray-500)}.file-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}@media (min-width: 640px){.file-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--spacing-md)}.file-info{flex-direction:row;align-items:center;gap:var(--spacing-sm)}}@media (min-width: 768px){.file-picker-actions{margin-bottom:var(--spacing-lg)}.file-card{padding:var(--spacing-md)}.file-icon{font-size:2rem;margin-bottom:var(--spacing-sm)}.file-name{font-size:.75rem}.file-size{font-size:.7rem}}@media (min-width: 1024px){.file-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.api-info-card{background:var(--white);border-radius:var(--border-radius);box-shadow:var(--shadow);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.api-info-card h3{margin-bottom:var(--spacing-sm);font-size:1.125rem}.api-endpoints{margin-top:var(--spacing-lg)}.api-endpoints h2{margin-bottom:var(--spacing-md);font-size:1.25rem}.api-endpoint-card{background:var(--white);border-radius:var(--border-radius);box-shadow:var(--shadow);margin-bottom:var(--spacing-md);overflow:hidden}.endpoint-header{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.http-method{display:inline-block;padding:.25rem .75rem;background:var(--success);color:var(--white);font-weight:600;font-size:.7rem;border-radius:.25rem;align-self:flex-start}.endpoint-url{font-family:Courier New,monospace;font-size:.75rem;color:var(--gray-900);word-break:break-all}.endpoint-body{padding:var(--spacing-md)}.endpoint-body h4{margin-bottom:var(--spacing-xs);font-size:.875rem}.endpoint-actions{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-md)}.endpoint-actions .btn{width:100%}.json-response{background:var(--gray-900);color:#a3e635;padding:var(--spacing-sm);border-radius:var(--border-radius-sm);overflow-x:auto;font-family:Courier New,monospace;font-size:.75rem;line-height:1.6}.endpoint-urls{margin-top:var(--spacing-md);margin-bottom:var(--spacing-md)}.endpoint-url-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.endpoint-example{margin-top:var(--spacing-md)}.endpoint-example-header{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}@media (min-width: 640px){.endpoint-header{flex-direction:row;justify-content:space-between;align-items:center}.endpoint-actions{flex-direction:row;gap:var(--spacing-sm)}.endpoint-actions .btn{width:auto}.endpoint-example-header{flex-direction:row;justify-content:space-between;align-items:center}}@media (min-width: 768px){.api-info-card{padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.api-info-card h3{margin-bottom:var(--spacing-md)}.api-endpoints{margin-top:var(--spacing-xl)}.api-endpoints h2,.api-endpoint-card{margin-bottom:var(--spacing-lg)}.endpoint-header{padding:var(--spacing-lg);gap:var(--spacing-md)}.endpoint-url{font-size:.875rem}.endpoint-body{padding:var(--spacing-lg)}.endpoint-body h4{margin-bottom:var(--spacing-sm)}.endpoint-actions{margin-top:var(--spacing-lg)}.json-response{padding:var(--spacing-md);font-size:.8125rem}.endpoint-urls{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.endpoint-url-row{gap:var(--spacing-sm)}.endpoint-example{margin-top:var(--spacing-lg)}}@media (min-width: 1024px){.json-response{padding:var(--spacing-lg)}}.snippet-tabs{display:inline-flex;background:var(--gray-100);border-radius:999px;padding:2px;gap:2px}.snippet-tab{border:none;background:transparent;padding:.25rem .625rem;font-size:.7rem;border-radius:999px;cursor:pointer;color:var(--gray-700);transition:var(--transition)}.snippet-tab:hover{background:var(--gray-50)}.snippet-tab--active{background:var(--white);color:var(--gray-900);box-shadow:0 0 0 1px var(--gray-200)}@media (min-width: 640px){.snippet-tab{padding:.25rem .75rem;font-size:.75rem}}.code-shell{margin-top:var(--spacing-xs);border-radius:var(--border-radius-sm);overflow:hidden;background:#020617;box-shadow:var(--shadow-sm);max-height:200px;display:flex;flex-direction:column}.code-shell-header{flex-shrink:0;display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#020617;border-bottom:1px solid #1f2937;font-size:.65rem;color:#9ca3af}.code-snippet{background:#020617;color:#e5e7eb;padding:.5rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Courier New,monospace;font-size:.7rem;line-height:1.5;overflow-x:auto;overflow-y:auto;max-height:180px}.code-shell-dot{width:6px;height:6px;border-radius:999px;background:#4b5563}.code-shell-title{margin-left:.35rem}@media (min-width: 640px){.code-shell{margin-top:var(--spacing-sm);border-radius:var(--border-radius);max-height:220px}.code-shell-header{gap:.35rem;padding:.35rem .75rem;font-size:.7rem}.code-snippet{padding:.5rem .75rem;font-size:.75rem;max-height:250px}.code-shell-dot{width:8px;height:8px}.code-shell-title{margin-left:.5rem}}@media (min-width: 768px){.code-snippet{font-size:.8125rem}}@media (min-width: 1024px){.code-shell{max-height:280px}.code-snippet{padding:var(--spacing-md);line-height:1.6;max-height:320px}}.code-snippet .token-keyword{color:#38bdf8}.code-snippet .token-string{color:#f97316}.code-snippet .token-function{color:#22c55e}.code-snippet .token-builtin{color:#a855f7}.code-snippet .token-operator{color:#e5e7eb}.code-snippet .token-punctuation{color:#9ca3af}.role-collection-wrapper{display:flex;flex-direction:column;gap:var(--spacing-sm)}.role-collection-empty{text-align:center;padding:var(--spacing-sm);border-radius:var(--border-radius-sm);background:var(--gray-50);color:var(--gray-500);font-size:.8125rem;border:1px dashed var(--gray-200)}.role-collection{display:flex;flex-direction:column;gap:var(--spacing-sm)}.role-item-card{background:var(--white);border-radius:var(--border-radius-sm);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);padding:var(--spacing-sm);transition:var(--transition)}.role-item-card:hover{box-shadow:var(--shadow)}.role-item-header{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.role-item-title{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.7rem;font-weight:600;color:var(--gray-600)}.role-item-actions{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.role-item-body{display:flex;flex-direction:column;gap:var(--spacing-sm)}.role-item-field{flex:1 1 100%}.role-item-field-label{display:block;margin-bottom:var(--spacing-xs);font-size:.7rem;font-weight:600;color:var(--gray-700)}.role-collection-add{margin-top:var(--spacing-sm)}@media (min-width: 480px){.role-item-card{padding:var(--spacing-md)}.role-item-header{flex-direction:row;justify-content:space-between;align-items:center;gap:var(--spacing-sm)}.role-item-title{font-size:.75rem}.role-item-body{flex-direction:row;flex-wrap:wrap;gap:var(--spacing-md)}.role-item-field{flex:1 1 150px}.role-item-field-label{font-size:.75rem}.role-collection-empty{padding:var(--spacing-md);font-size:.875rem}}@media (min-width: 1024px){.role-item-field{flex:1 1 180px}}.user-roles-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.user-role-pill{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:.125rem .35rem;border-radius:9999px;font-size:.65rem;font-weight:500;border:1px solid transparent;white-space:nowrap;transition:var(--transition)}.user-role-pill:hover{transform:translateY(-1px)}.user-role-pill--active{background:#ccfbf1;border-color:#99f6e4;color:#0f766e}.user-role-pill--inactive{background:var(--gray-100);border-color:var(--gray-200);color:var(--gray-600)}.user-role-pill-website{font-weight:600}.user-role-pill-role{font-weight:500;text-transform:uppercase;letter-spacing:.03em;font-size:.65rem}.user-role-pill-separator{color:var(--gray-400)}.user-roles-empty{font-size:.7rem;color:var(--gray-500)}@media (min-width: 640px){.user-role-pill{padding:.15rem .4rem;font-size:.7rem}.user-role-pill-role{font-size:.7rem}.user-roles-empty{font-size:.75rem}}@media (min-width: 1024px){.user-role-pill{padding:.2rem .5rem;font-size:.75rem}.user-role-pill-role{font-size:.75rem}}.link-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.link-modal{background:#fff;padding:24px;border-radius:8px;box-shadow:0 4px 6px #0000001a;min-width:400px}.link-modal h3{margin-top:0;margin-bottom:16px}.link-modal-field{margin-bottom:16px}.link-modal-field label{display:block;margin-bottom:4px;font-weight:500}.link-modal-field input{width:100%;padding:8px;border:1px solid #d1d5db;border-radius:4px;font-size:14px}.link-modal-actions{display:flex;gap:8px;justify-content:flex-end}.link-modal-actions button{padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px}.link-modal-actions button:first-child{background-color:#3b82f6;color:#fff;border:none}.link-modal-actions button:last-child{background-color:#e5e7eb;border:1px solid #d1d5db}.rich-editor-content a{color:#3b82f6;cursor:pointer}.rich-editor-content a:hover{color:#2563eb}.drag-handle-cell{width:40px;padding:8px!important;cursor:move;text-align:center;user-select:none;-webkit-user-select:none;-moz-user-select:none;touch-action:none}.drag-handle{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;width:16px;margin:0 auto;padding:4px;border-radius:4px;transition:background .2s;pointer-events:none}.drag-handle:hover{background:#f0f0f0}.drag-handle span{width:4px;height:4px;background:#666;border-radius:50%}.table tbody tr{transition:all .2s ease;position:relative}.table tbody tr.dragging,.table tbody tr.touch-dragging{opacity:.5;z-index:1000}.table tbody tr.drag-over{border-top:3px solid #007bff;background:#f0f8ff}.table tbody tr:hover{background:#f8f9fa}@media (max-width: 768px){.drag-handle-cell{width:30px;padding:4px!important}.drag-handle{width:14px;gap:1px}.drag-handle span{width:3px;height:3px}.table tbody tr.touch-dragging{box-shadow:0 5px 15px #0000004d;transform:scale(1.02)}}.table tbody tr.touch-dragging *{user-select:none;-webkit-user-select:none;-moz-user-select:none}
