@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#0f1115;--bg-secondary:#1a1d24;--bg-tertiary:#22262e;--bg-hover:#282c35;--bg-active:#2e333d;--text-primary:#fff;--text-secondary:#a0a4ad;--text-tertiary:#6b7080;--text-muted:#4a4f5c;--accent:#4f7df9;--accent-hover:#3d6ce8;--accent-light:#4f7df926;--accent-glow:#4f7df94d;--success:#34d399;--success-bg:#34d3991f;--warning:#fbbf24;--warning-bg:#fbbf241f;--error:#f87171;--error-bg:#f871711f;--info:#60a5fa;--info-bg:#60a5fa1f;--border:#2a2e37;--border-hover:#3a3f4a;--border-focus:var(--accent);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-xl:0 16px 48px #0009;--shadow-glow:0 0 20px var(--accent-glow);--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.5rem;--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px;--max-content-width:1400px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.35s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:var(--accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-hover)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.3}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{color:var(--text-secondary);line-height:1.7}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--border-hover)}.card-glass{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);background:#1a1d24b3}.stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-sm);transition:all var(--transition-base);flex-direction:column;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg,var(--accent),transparent);opacity:0;height:3px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.stat-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-card .stat-label{font-size:var(--text-sm);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.stat-card .stat-value{font-size:var(--text-2xl);color:var(--text-primary);font-weight:700}.stat-card .stat-change{font-size:var(--text-sm);font-weight:500}.stat-card .stat-change.positive{color:var(--success)}.stat-card .stat-change.negative{color:var(--error)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;outline:none;padding:10px 20px;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-hover)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background:#ef4444}.btn-sm{font-size:var(--text-xs);padding:6px 12px}.btn-lg{font-size:var(--text-base);padding:14px 28px}.btn-icon{border-radius:var(--radius-sm);padding:8px}.input-group{gap:var(--space-xs);flex-direction:column;display:flex}.input-group label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.input{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);transition:all var(--transition-fast);outline:none;width:100%;padding:10px 14px}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.input::placeholder{color:var(--text-muted)}textarea.input{resize:vertical;min-height:100px}select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7080' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;align-items:center;padding:3px 10px;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-error{background:var(--error-bg);color:var(--error)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.table-container{border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-align:left;font-size:var(--text-sm);color:var(--text-tertiary);background:var(--bg-secondary);border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 16px;font-weight:600}tbody td{font-size:var(--text-sm);color:var(--text-secondary);border-bottom:1px solid var(--border);padding:12px 16px}tbody tr{transition:background var(--transition-fast)}tbody tr:hover{background:var(--bg-hover)}tbody tr:last-child td{border-bottom:none}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn var(--transition-fast);padding:var(--space-md);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:85vh;animation:slideUp var(--transition-base);overflow-y:auto}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.modal-header h2{font-size:var(--text-lg)}.modal-body{padding:var(--space-lg)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-sm);padding:var(--space-lg);border-top:1px solid var(--border);display:flex}.page-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.page-header h1{font-size:var(--text-2xl)}.page-header .page-actions{align-items:center;gap:var(--space-sm);display:flex}.page-content{gap:var(--space-lg);flex-direction:column;display:flex}.grid-2{gap:var(--space-lg);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}@media (max-width:1200px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:100;transition:transform var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:var(--space-lg);border-bottom:1px solid var(--border);align-items:center;gap:var(--space-md);display:flex}.sidebar-header .logo{background:var(--accent);border-radius:var(--radius-md);width:36px;height:36px;font-weight:700;font-size:var(--text-lg);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-header .brand-name{font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-nav{padding:var(--space-md);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.sidebar-nav a,.sidebar-nav button{align-items:center;gap:var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);transition:all var(--transition-fast);cursor:pointer;text-align:left;width:100%;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;padding:10px 14px;display:flex}.sidebar-nav a:hover,.sidebar-nav button:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-nav a.active,.sidebar-nav button.active{background:var(--accent-light);color:var(--accent)}.sidebar-nav a.active svg,.sidebar-nav button.active svg{color:var(--accent)}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border)}.sidebar-user{align-items:center;gap:var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);padding:10px 14px;display:flex}.sidebar-user:hover{background:var(--bg-hover)}.sidebar-user .avatar{border-radius:var(--radius-full);background:var(--accent);width:32px;height:32px;font-weight:600;font-size:var(--text-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user .user-info{flex:1;min-width:0}.sidebar-user .user-name{font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.sidebar-user .user-role{font-size:var(--text-xs);color:var(--text-tertiary)}.main-content{margin-left:var(--sidebar-width);padding:var(--space-xl);flex:1;max-width:100%}.main-content-inner{max-width:var(--max-content-width);margin:0 auto}.toast-container{bottom:var(--space-lg);right:var(--space-lg);gap:var(--space-sm);z-index:2000;flex-direction:column;display:flex;position:fixed}.toast{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md)var(--space-lg);align-items:center;gap:var(--space-md);min-width:300px;max-width:420px;box-shadow:var(--shadow-lg);animation:slideInRight var(--transition-base);display:flex}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--error)}.toast.warning{border-left:3px solid var(--warning)}.toast.info{border-left:3px solid var(--info)}.empty-state{padding:var(--space-3xl)var(--space-lg);text-align:center;justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.empty-state svg{color:var(--text-muted);margin-bottom:var(--space-sm)}.empty-state h3{font-size:var(--text-lg);color:var(--text-secondary)}.empty-state p{color:var(--text-tertiary);max-width:400px}.loading-spinner{justify-content:center;align-items:center;display:inline-flex}.loading-spinner:after{content:"";border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.loading-spinner.lg:after{border-width:3px;width:32px;height:32px}.loading-page{justify-content:center;align-items:center;min-height:400px;display:flex}.tabs{border-bottom:1px solid var(--border);margin-bottom:var(--space-lg);gap:2px;display:flex}.tab{font-size:var(--text-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);font-weight:500;font-family:var(--font-sans);background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 20px}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.search-input{position:relative}.search-input svg{color:var(--text-muted);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-input .input{padding-left:42px}.kanban-board{gap:var(--space-md);padding-bottom:var(--space-md);min-height:500px;display:flex;overflow-x:auto}.kanban-column{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;flex-shrink:0;min-width:280px;max-width:320px;display:flex}.kanban-column-header{padding:var(--space-md);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.kanban-column-header h3{font-size:var(--text-sm);font-weight:600}.kanban-column-header .count{font-size:var(--text-xs);color:var(--text-tertiary);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:2px 8px}.kanban-column-body{padding:var(--space-sm);gap:var(--space-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.kanban-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);cursor:grab;transition:all var(--transition-fast)}.kanban-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.kanban-card:active{cursor:grabbing}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade{animation:fadeIn var(--transition-base)}.animate-slide-up{animation:slideUp var(--transition-base)}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary)25%,var(--bg-hover)50%,var(--bg-tertiary)75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}@media (max-width:768px){:root{--sidebar-width:0px}.sidebar{transform:translate(-100%)}.sidebar.open{width:260px;transform:translate(0)}.main-content{padding:var(--space-md);margin-left:0}.page-header h1{font-size:var(--text-xl)}.mobile-menu-btn{display:flex!important}.modal{margin:var(--space-md);max-height:90vh}}@media (min-width:769px){.mobile-menu-btn,.mobile-overlay{display:none!important}}.chart-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg)}.chart-container h3{font-size:var(--text-base);margin-bottom:var(--space-md);color:var(--text-secondary)}.accordion-item{border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-fast);overflow:hidden}.accordion-item+.accordion-item{margin-top:var(--space-sm)}.accordion-header{padding:var(--space-md)var(--space-lg);background:var(--bg-secondary);cursor:pointer;color:var(--text-primary);transition:all var(--transition-fast);width:100%;font-weight:500;font-family:var(--font-sans);font-size:var(--text-sm);text-align:left;border:none;justify-content:space-between;align-items:center;display:flex}.accordion-header:hover{background:var(--bg-hover)}.accordion-header svg{transition:transform var(--transition-fast);color:var(--text-tertiary);flex-shrink:0}.accordion-item.open .accordion-header svg{transform:rotate(180deg)}.accordion-body{padding:0 var(--space-lg)var(--space-lg);color:var(--text-secondary);font-size:var(--text-sm);line-height:1.7}.file-upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-fast)}.file-upload-zone:hover{border-color:var(--accent);background:var(--accent-light)}.file-upload-zone svg{color:var(--text-muted);margin-bottom:var(--space-sm)}.file-upload-zone p{font-size:var(--text-sm);color:var(--text-tertiary)}.login-page{background:var(--bg-primary);min-height:100vh;padding:var(--space-lg);justify-content:center;align-items:center;display:flex}.login-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:420px;padding:var(--space-2xl);animation:slideUp var(--transition-slow)}.login-card .login-logo{justify-content:center;align-items:center;gap:var(--space-md);margin-bottom:var(--space-2xl);display:flex}.login-card .login-logo .logo-icon{background:var(--accent);border-radius:var(--radius-lg);width:48px;height:48px;font-weight:800;font-size:var(--text-xl);color:#fff;justify-content:center;align-items:center;display:flex}.login-card .login-logo h1{font-size:var(--text-xl);font-weight:700}.login-form{gap:var(--space-md);flex-direction:column;display:flex}.login-form .btn-primary{width:100%;margin-top:var(--space-sm);padding:12px}.portfolio-page{background:var(--bg-primary);min-height:100vh}.portfolio-hero{padding:var(--space-3xl)var(--space-xl);text-align:center}.portfolio-hero h1{font-size:var(--text-4xl);background:linear-gradient(135deg,var(--text-primary),var(--accent));-webkit-text-fill-color:transparent;margin-bottom:var(--space-md);-webkit-background-clip:text;background-clip:text;font-weight:800}.portfolio-hero p{font-size:var(--text-lg);max-width:600px;margin:0 auto}.portfolio-grid{gap:var(--space-lg);padding:0 var(--space-xl)var(--space-3xl);max-width:var(--max-content-width);grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin:0 auto;display:grid}.portfolio-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-base);overflow:hidden}.portfolio-card:hover{box-shadow:var(--shadow-lg);border-color:var(--border-hover);transform:translateY(-4px)}.portfolio-card-image{aspect-ratio:16/9;background:var(--bg-tertiary);justify-content:center;align-items:center;width:100%;display:flex}.portfolio-card-body{padding:var(--space-lg)}.portfolio-card-body h3{font-size:var(--text-base);margin-bottom:var(--space-xs)}.portfolio-card-body p{font-size:var(--text-sm);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.ticket-thread{gap:var(--space-md);flex-direction:column;display:flex}.ticket-message{gap:var(--space-md);animation:fadeIn var(--transition-fast);display:flex}.ticket-message .message-body{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);flex:1}.ticket-message.own .message-body{background:var(--accent-light);border-color:var(--accent)}.section-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.section-header h2{font-size:var(--text-lg)}.filter-bar{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.filter-pill{border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast);padding:6px 16px;font-weight:500}.filter-pill:hover{border-color:var(--border-hover);color:var(--text-primary)}.filter-pill.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}
