@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--synplai-black: #1c1c1c;--synplai-warm: #706c61;--synplai-sage: #cfd2b2;--synplai-white: #ffffff;--synplai-pure: #000000;--synplai-blue: #0c5a9d;--synplai-navy: #00091d;--synplai-teal: #afd1c8;--synplai-dark: #06120f;--color-bg: #00091d;--color-bg-elevated: #040d1a;--color-bg-card: #091524;--color-bg-hover: #0e1f33;--color-border: #162843;--color-border-soft: rgba(175, 209, 200, .07);--color-primary: #0c5a9d;--color-primary-hover: #1472be;--color-primary-500: #0c5a9d;--color-primary-600: #0a4d88;--color-primary-400: #3d8ec8;--color-primary-glow: rgba(12, 90, 157, .3);--color-accent: #afd1c8;--color-accent-glow: rgba(175, 209, 200, .2);--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .12);--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .12);--color-danger: #ef4444;--color-danger-bg: rgba(239, 68, 68, .12);--color-info: #afd1c8;--color-info-bg: rgba(175, 209, 200, .12);--color-text: #ffffff;--color-text-muted: #cfd2b2;--color-text-subtle: #706c61;--sidebar-bg: #1c1c1c;--sidebar-bg-elevated: #141414;--sidebar-bg-hover: #262626;--sidebar-bg-active: rgba(12, 90, 157, .9);--sidebar-text: #cfd2b2;--sidebar-text-muted: #706c61;--sidebar-text-active: #ffffff;--sidebar-border: #2a2a2a;--sidebar-section: #5a5a5a;--topbar-bg: #0c5a9d;--topbar-text: #ffffff;--topbar-text-muted: rgba(255,255,255,.75);--topbar-hover: rgba(255,255,255,.12);--topbar-border: rgba(255,255,255,.1);--topbar-shadow: 0 2px 12px rgba(0,0,0,.35);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 18px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.35);--shadow-md: 0 4px 14px rgba(0,0,0,.45);--shadow-lg: 0 8px 28px rgba(0,0,0,.55);--shadow-glow-blue: 0 0 20px rgba(12,90,157,.25);--shadow-glow-purple: 0 0 20px rgba(175,209,200,.15);--sidebar-w: 240px;--header-h: 58px;--bottom-nav-h: 64px;--transition: all .18s ease;--transition-slow: all .28s ease}[data-theme=light]{--color-bg: #f0f2f5;--color-bg-elevated: #e4e8ed;--color-bg-card: #ffffff;--color-bg-hover: #f5f7fa;--color-border: #d8dde5;--color-border-soft: rgba(12, 90, 157, .1);--color-primary-400: #0c5a9d;--color-primary-glow: rgba(12, 90, 157, .15);--color-accent-glow: rgba(175, 209, 200, .25);--color-success-bg: rgba(34, 197, 94, .08);--color-warning-bg: rgba(245, 158, 11, .08);--color-danger-bg: rgba(239, 68, 68, .08);--color-info-bg: rgba(175, 209, 200, .12);--color-text: #1c1c1c;--color-text-muted: #706c61;--color-text-subtle: #9ca3af;--shadow-sm: 0 1px 4px rgba(0,0,0,.08);--shadow-md: 0 3px 12px rgba(0,0,0,.1);--shadow-lg: 0 6px 22px rgba(0,0,0,.12);--shadow-glow-blue: 0 0 16px rgba(12,90,157,.15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;min-width:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;overflow-x:hidden;width:100%;transition:background-color .25s ease,color .25s ease}#root{min-height:100vh;overflow-x:hidden;width:100%}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}img{max-width:100%;display:block}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh;transition:var(--transition-slow)}.app-content{flex:1;padding:var(--space-6) var(--space-8);margin-top:var(--header-h);max-width:1440px;width:100%;box-sizing:border-box}.header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:var(--topbar-bg);border-bottom:1px solid var(--topbar-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-5) 0 0;z-index:200;box-shadow:var(--topbar-shadow);transition:none}.header-brand{display:flex;align-items:center;justify-content:center;gap:var(--space-3);width:var(--sidebar-w);padding:0 var(--space-5);flex-shrink:0;border-right:1px solid var(--topbar-border);height:100%;cursor:pointer}.header-brand-icon{width:32px;height:32px;background:#fff3;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.header-brand-name{font-size:15px;font-weight:800;color:var(--topbar-text);letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-left{display:flex;flex-direction:column;padding-left:var(--space-6);flex:1}.header-title{font-size:16px;font-weight:700;color:var(--topbar-text);letter-spacing:-.2px;line-height:1.2}.header-subtitle{font-size:12px;color:var(--topbar-text-muted);font-weight:400}.header-right{display:flex;align-items:center;gap:var(--space-2)}.header-btn{width:36px;height:36px;border-radius:var(--radius-md);background:var(--topbar-hover);border:1px solid var(--topbar-border);color:var(--topbar-text);display:flex;align-items:center;justify-content:center;font-size:17px;transition:var(--transition);cursor:pointer}.header-btn:hover{background:#fff3}.header-theme-toggle{width:36px;height:36px;border-radius:var(--radius-md);background:var(--topbar-hover);border:1px solid var(--topbar-border);color:var(--topbar-text);display:flex;align-items:center;justify-content:center;font-size:17px;cursor:pointer;transition:var(--transition)}.header-theme-toggle:hover{background:#ffffff38}.header-user-chip{display:flex;align-items:center;gap:var(--space-2);padding:5px 10px 5px 5px;border-radius:var(--radius-full);background:var(--topbar-hover);border:1px solid var(--topbar-border);cursor:pointer;transition:var(--transition);text-decoration:none}.header-user-chip:hover{background:#fff3}.header-user-avatar{width:28px;height:28px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}.header-user-name{font-size:13px;font-weight:600;color:var(--topbar-text);max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-mobile-logo{display:none;align-items:center;gap:var(--space-2)}.header-mobile-profile{display:none;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:#fff3;border:1px solid var(--topbar-border);color:#fff;font-size:12px;font-weight:700;cursor:pointer;flex-shrink:0;letter-spacing:.5px;transition:var(--transition)}.header-mobile-profile:hover{background:#ffffff4d}@media (max-width: 768px){.header-mobile-logo,.header-mobile-profile{display:flex!important}.header-left,.header-brand,.header-user-chip{display:none!important}.header-theme-toggle{display:flex}.header{padding:0 var(--space-4);justify-content:space-between}}.sidebar{position:fixed;top:var(--header-h);left:0;width:var(--sidebar-w);height:calc(100vh - var(--header-h));background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;z-index:100;overflow:hidden;transition:var(--transition-slow)}.sidebar-profile{padding:var(--space-5) var(--space-4);border-bottom:1px solid var(--sidebar-border);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);text-align:center}.sidebar-profile-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--synplai-blue),var(--synplai-teal));display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;flex-shrink:0;border:2px solid rgba(175,209,200,.3);overflow:hidden;cursor:pointer;transition:var(--transition)}.sidebar-profile-avatar:hover{border-color:var(--synplai-teal);transform:scale(1.03)}.sidebar-profile-name{font-size:13px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.sidebar-profile-role{font-size:11px;color:var(--sidebar-text-muted);font-weight:500}.sidebar-profile-status{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--sidebar-text-muted)}.sidebar-status-dot{width:7px;height:7px;border-radius:50%;background:var(--color-success);animation:statusPulse 2.5s ease-in-out infinite;flex-shrink:0}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.5}}.sidebar-logo,.sidebar-logo-icon,.sidebar-logo-text,.sidebar-logo-name,.sidebar-logo-sub{display:none}.sidebar-nav{flex:1;padding:var(--space-3) var(--space-3);overflow-y:auto;display:flex;flex-direction:column;gap:2px}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--sidebar-border);border-radius:99px}.sidebar-section-label{font-size:10px;font-weight:700;color:var(--sidebar-section);text-transform:uppercase;letter-spacing:1.2px;padding:var(--space-4) var(--space-3) var(--space-2)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:9px var(--space-3);border-radius:var(--radius-md);font-size:13px;font-weight:500;color:var(--sidebar-text);transition:var(--transition);position:relative;border:1px solid transparent;text-decoration:none}.sidebar-link:hover{background:var(--sidebar-bg-hover);color:#fff}.sidebar-link.active{background:var(--sidebar-bg-active);color:var(--sidebar-text-active);border-color:#0c5a9d66;font-weight:600}.sidebar-link.active .sidebar-link-icon{filter:brightness(1.3)}.sidebar-link-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0;line-height:1}.sidebar-link-badge{margin-left:auto;background:var(--color-primary);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--radius-full);min-width:20px;text-align:center}.sidebar-footer{padding:var(--space-3) var(--space-3) var(--space-4);border-top:1px solid var(--sidebar-border)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);text-decoration:none;color:var(--sidebar-text)}.sidebar-user:hover{background:var(--sidebar-bg-hover)}.sidebar-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--synplai-blue),var(--synplai-teal));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:10px;color:var(--sidebar-text-muted)}.sidebar-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--color-danger);color:#fff;font-size:10px;font-weight:800;border-radius:999px;margin-left:auto;line-height:1;animation:badgePop .3s cubic-bezier(.34,1.56,.64,1)}.sidebar-client-label{font-size:10px;color:var(--sidebar-text-muted);padding:4px var(--space-3) 6px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5);gap:var(--space-3)}.card-title{font-size:15px;font-weight:700;color:var(--color-text)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);position:relative;overflow:hidden;transition:var(--transition-slow);cursor:default}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--stat-color, var(--color-primary));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-border-soft)}.stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:var(--space-3);background:var(--stat-icon-bg, var(--color-primary-glow))}.stat-value{font-size:28px;font-weight:800;color:var(--color-text);letter-spacing:-.8px;line-height:1;margin-bottom:var(--space-1)}.stat-label{font-size:12px;color:var(--color-text-muted);font-weight:500}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:8px var(--space-4);border-radius:var(--radius-md);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:var(--transition);white-space:nowrap;text-decoration:none}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px var(--color-primary-glow)}.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 14px var(--color-primary-glow)}.btn-secondary{background:var(--color-bg-hover);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-card);border-color:var(--color-primary);color:var(--color-primary-400)}.btn-danger{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:var(--color-danger);color:#fff}.btn-ghost{background:transparent;color:var(--color-text-muted);border:1px solid transparent}.btn-ghost:hover{background:var(--color-bg-hover);color:var(--color-text)}.btn-sm{padding:5px var(--space-3);font-size:12px}.btn-lg{padding:var(--space-3) var(--space-8);font-size:14px}.btn-export{display:inline-flex;align-items:center;gap:8px;padding:8px var(--space-4);background:var(--color-success-bg);border:1px solid rgba(34,197,94,.25);border-radius:var(--radius-md);color:#4ade80;font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition)}.btn-export:hover{background:#22c55e33;border-color:#22c55e73;transform:translateY(-1px)}.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.form-label{font-size:12px;font-weight:600;color:var(--color-text-muted);letter-spacing:.3px;text-transform:uppercase}.form-input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px var(--space-4);font-size:14px;color:var(--color-text);transition:var(--transition);outline:none;width:100%}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.form-input::placeholder{color:var(--color-text-subtle)}[data-theme=light] .form-input{background:#fff}.form-textarea{resize:vertical;min-height:100px}.form-select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.form-error{font-size:12px;color:var(--color-danger);display:flex;align-items:center;gap:4px}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-border)}table{width:100%;border-collapse:collapse}thead{background:var(--color-bg-elevated)}[data-theme=light] thead{background:#f8f9fb}th{padding:var(--space-3) var(--space-5);text-align:left;font-size:11px;font-weight:700;color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;border-bottom:2px solid var(--color-border)}td{padding:12px var(--space-5);font-size:14px;color:var(--color-text);border-top:1px solid var(--color-border)}tbody tr{transition:var(--transition)}tbody tr:hover{background:var(--color-bg-hover)}[data-theme=light] tbody tr:hover{background:#f5f7fa}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:700;letter-spacing:.2px;border:1px solid transparent;white-space:nowrap}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}.badge-open{background:#0c5a9d1f;color:var(--color-primary-400);border-color:#0c5a9d33}.badge-in_progress{background:#f59e0b1f;color:#fcd34d;border-color:#f59e0b33}.badge-qa_validation{background:#afd1c81f;color:var(--color-accent);border-color:#afd1c840}.badge-qa_approved{background:#fbbf2424;color:#fbbf24;border-color:#fbbf244d}.badge-homologation{background:#6366f124;color:#a5b4fc;border-color:#6366f14d}.badge-homologation_approved{background:#22c55e1f;color:#4ade80;border-color:#22c55e40}.badge-homologation_rejected{background:#ef44441f;color:#f87171;border-color:#ef444440}.badge-pending_validation{background:#f973161f;color:#fb923c;border-color:#f9731633}.badge-resolved{background:#22c55e1f;color:#4ade80;border-color:#22c55e33}.badge-closed{background:#64748b1f;color:#94a3b8;border-color:#64748b33}.badge-problem{background:#ef44441f;color:#f87171;border-color:#ef444433}.badge-feature_request{background:#afd1c81f;color:var(--color-accent);border-color:#afd1c833}.badge-admin{background:#ef44441f;color:#f87171;border-color:#ef444433}.badge-developer{background:#0c5a9d1f;color:var(--color-primary-400);border-color:#0c5a9d33}.badge-client{background:#22c55e1f;color:#4ade80;border-color:#22c55e33}[data-theme=light] .badge-in_progress{color:#d97706;border-color:#f59e0b4d}[data-theme=light] .badge-resolved{color:#16a34a;border-color:#22c55e4d}[data-theme=light] .badge-closed{color:#64748b}[data-theme=light] .badge-problem,[data-theme=light] .badge-homologation_rejected{color:#dc2626}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-6);animation:fadeIn .15s ease}.modal-box{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}[data-theme=light] .modal-box{box-shadow:0 20px 60px #00000026}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6) var(--space-4);border-bottom:1px solid var(--color-border)}.modal-title{font-size:16px;font-weight:700;color:var(--color-text)}.modal-close{width:30px;height:30px;border-radius:var(--radius-md);background:var(--color-bg-hover);border:none;color:var(--color-text-muted);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.modal-close:hover{background:var(--color-danger-bg);color:var(--color-danger)}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6) var(--space-5);border-top:1px solid var(--color-border)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-4);flex-wrap:wrap}.page-header-left h1{font-size:22px;font-weight:800;color:var(--color-text);letter-spacing:-.4px;margin-bottom:4px}.page-header-left p{font-size:13px;color:var(--color-text-muted)}.filter-bar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);flex-wrap:wrap}.filter-bar .form-input{max-width:260px}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);color:var(--color-text-muted)}.empty-state-icon{font-size:44px;margin-bottom:var(--space-4);opacity:.45}.empty-state h3{font-size:17px;font-weight:700;color:var(--color-text-muted);margin-bottom:var(--space-2)}.empty-state p{font-size:13px;color:var(--color-text-subtle)}.login-page{min-height:100vh;display:flex;align-items:stretch;background:var(--color-bg);position:relative;overflow:hidden}.login-panel-left{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(155deg,var(--synplai-blue) 0%,#00091d 60%,#06120f 100%);padding:var(--space-12);position:relative;overflow:hidden;min-height:100vh}.login-panel-left:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 50%,rgba(175,209,200,.12) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(12,90,157,.3) 0%,transparent 50%);pointer-events:none}.login-left-content{position:relative;z-index:1;text-align:center;max-width:360px}.login-left-logo{width:72px;height:72px;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto var(--space-6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-left-title{font-size:28px;font-weight:800;color:#fff;letter-spacing:-.5px;margin-bottom:var(--space-3);line-height:1.2}.login-left-sub{font-size:15px;color:#ffffffa6;line-height:1.6}.login-deco-1,.login-deco-2,.login-deco-3{position:absolute;border-radius:50%;pointer-events:none}.login-deco-1{width:300px;height:300px;background:#afd1c80f;top:-80px;right:-80px}.login-deco-2{width:200px;height:200px;background:#0c5a9d26;bottom:40px;left:-60px}.login-deco-3{width:120px;height:120px;background:#afd1c814;bottom:160px;right:40px}.login-panel-right{width:440px;min-width:440px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-card);padding:var(--space-12) var(--space-8);position:relative}[data-theme=light] .login-panel-right{background:#fff;box-shadow:-4px 0 24px #00000014}.login-form-inner{width:100%;max-width:340px}.login-glow,.login-glow-1,.login-glow-2{display:none}.login-card{width:100%}.login-logo{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6)}.login-logo-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--color-primary),var(--synplai-teal));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:20px}.login-logo-name{font-size:18px;font-weight:800;color:var(--color-text);letter-spacing:-.3px}.login-title{font-size:24px;font-weight:800;color:var(--color-text);letter-spacing:-.4px;margin-bottom:var(--space-2);text-align:left}.login-subtitle{font-size:14px;color:var(--color-text-muted);margin-bottom:var(--space-6);text-align:left}.login-error{background:var(--color-danger-bg);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:13px;color:var(--color-danger);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.chat-container{display:flex;flex-direction:column;gap:var(--space-4);max-height:400px;overflow-y:auto;padding:var(--space-4);background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border)}.chat-message{display:flex;gap:var(--space-3);animation:fadeIn .2s ease}.chat-message.own{flex-direction:row-reverse}.chat-avatar{width:30px;height:30px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--synplai-teal));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.chat-bubble{max-width:70%;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4)}.chat-message.own .chat-bubble{background:#0c5a9d1f;border-color:#0c5a9d33}.chat-bubble-author{font-size:11px;font-weight:600;color:var(--color-primary-400);margin-bottom:4px}.chat-bubble-content{font-size:14px;color:var(--color-text);line-height:1.5}.chat-bubble-time{font-size:10px;color:var(--color-text-subtle);margin-top:4px}.chat-input-area{display:flex;gap:var(--space-3);margin-top:var(--space-4)}.chat-input-area .form-input{flex:1}.ticket-detail-grid{display:grid;grid-template-columns:1fr 300px;gap:var(--space-6)}.ticket-meta{display:flex;flex-direction:column;gap:var(--space-1)}.ticket-meta-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--color-border);font-size:14px}.ticket-meta-row:last-child{border-bottom:none}.ticket-meta-label{color:var(--color-text-subtle);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.ticket-meta-value{color:var(--color-text);text-align:right}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}@keyframes shimmer{0%{background-position:-800px 0}to{background-position:800px 0}}@keyframes toastSlideIn{0%{opacity:0;transform:translate(120%) scale(.85)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastProgress{0%{width:100%}to{width:0%}}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.45}}.animate-fade{animation:fadeIn .3s ease}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--space-12)}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .65s linear infinite}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-subtle)}.skeleton{background:linear-gradient(90deg,var(--color-bg-card) 25%,var(--color-bg-elevated) 50%,var(--color-bg-card) 75%);background-size:800px 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-row{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--color-border)}.skeleton-row:last-child{border-bottom:none}.skeleton-avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0}.skeleton-line{height:11px;border-radius:6px}.skeleton-text{flex:1;display:flex;flex-direction:column;gap:8px}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-6{margin-bottom:var(--space-6)}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:13px}.font-bold{font-weight:700}.w-full{width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}.bottom-nav{display:none}@media (max-width: 768px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-h);background:#1c1c1cf7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--sidebar-border);z-index:200;align-items:stretch;padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -4px 20px #0006}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 4px;background:none;border:none;cursor:pointer;color:var(--sidebar-text-muted);transition:var(--transition);text-decoration:none;position:relative;-webkit-tap-highlight-color:transparent}.bottom-nav-item:active{background:#ffffff0d;border-radius:var(--radius-md)}.bottom-nav-item.active{color:var(--synplai-teal)}.bottom-nav-item.active .bottom-nav-icon{transform:scale(1.15)}.bottom-nav-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center}.bottom-nav-icon{font-size:21px;line-height:1;transition:transform .2s cubic-bezier(.34,1.56,.64,1);display:block}.bottom-nav-label{font-size:10px;font-weight:600;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56px}.bottom-nav-badge{position:absolute;top:-4px;right:-8px;background:var(--color-danger);color:#fff;font-size:9px;font-weight:800;min-width:16px;height:16px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1.5px solid var(--sidebar-bg);animation:badgePop .3s cubic-bezier(.34,1.56,.64,1)}.bottom-nav-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--synplai-teal);border-radius:0 0 var(--radius-sm) var(--radius-sm)}.bottom-nav-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:190;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease}.bottom-nav-drawer{position:fixed;bottom:var(--bottom-nav-h);left:0;right:0;background:var(--sidebar-bg);border-top:1px solid var(--sidebar-border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:195;animation:slideUp .25s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:0 -8px 32px #00000080}.bottom-nav-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--sidebar-border)}.bottom-nav-drawer-items{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);padding:var(--space-3) var(--space-4)}.bottom-nav-drawer-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:var(--space-3);border-radius:var(--radius-md);color:var(--sidebar-text);text-decoration:none;font-size:12px;font-weight:600;transition:var(--transition);background:var(--sidebar-bg-hover);border:1px solid var(--sidebar-border);text-align:center;-webkit-tap-highlight-color:transparent}.bottom-nav-drawer-item span:first-child{font-size:22px}.bottom-nav-drawer-item.active{color:var(--synplai-teal);background:#afd1c814;border-color:#afd1c833}.bottom-nav-drawer-footer{padding:var(--space-3) var(--space-4) var(--space-4);border-top:1px solid var(--sidebar-border)}.bottom-nav-drawer-logout{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-3);background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--color-danger);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition)}.bottom-nav-drawer-logout:active{background:#ef444433}}.ticket-mobile-card,.mobile-cards-list{display:none}@media (max-width: 768px){.ticket-mobile-card{display:flex;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);flex-direction:column;gap:var(--space-2);text-decoration:none;color:inherit;transition:var(--transition);-webkit-tap-highlight-color:transparent}.ticket-mobile-card:active{transform:scale(.99)}.mobile-cards-list{display:flex!important;flex-direction:column}.ticket-desktop-table{display:none!important}}.ticket-mobile-card-title{font-size:14px;font-weight:700;color:var(--color-primary-400);line-height:1.4}.ticket-mobile-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ticket-mobile-card-footer{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--color-text-subtle);margin-top:4px;padding-top:8px;border-top:1px solid var(--color-border)}@media (max-width: 768px){.app-main{margin-left:0}.header{left:0}.sidebar{display:none}.app-content{padding:var(--space-4);padding-bottom:calc(var(--bottom-nav-h) + 16px);margin-top:var(--header-h);overflow-x:hidden}.ticket-detail-grid,.grid-2,.grid-3{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4)}.page-header-left h1{font-size:18px}.page-header>*:last-child{width:100%}.page-header>*:last-child .btn,.page-header>*:last-child .btn-export,.page-header>*:last-child a.btn{width:100%;justify-content:center}.btn{min-height:44px;padding:var(--space-3) var(--space-4)}.btn-sm{min-height:36px}.btn-lg{min-height:48px}.form-input{min-height:44px;font-size:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.stat-card{padding:var(--space-4)}.stat-value{font-size:22px}.stat-icon{width:34px;height:34px;font-size:17px}.card{padding:var(--space-4)}.card-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.modal-overlay{padding:0;align-items:flex-end}.modal-box{max-width:100%;max-height:92vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;margin:0}.modal-footer{flex-direction:column!important;gap:var(--space-2)!important}.modal-footer .btn{width:100%;justify-content:center}.mobile-table-hide{display:none!important}.mobile-card-list{display:flex!important;flex-direction:column;gap:8px}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}.header-title{font-size:14px}.header-subtitle{font-size:11px}.chat-container{max-height:280px}.chat-bubble{max-width:85%}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar .form-input,.filter-bar select{max-width:100%!important;width:100%!important}.filter-bar>*{width:100%}.filter-bar .btn-ghost.btn-sm{width:auto;align-self:flex-start}.new-ticket-grid{grid-template-columns:1fr!important}.new-ticket-sidebar{display:none}.new-ticket-form-grid{grid-template-columns:1fr!important}.priority-grid-mobile{grid-template-columns:repeat(2,1fr)!important}.admin-config-grid{grid-template-columns:1fr!important}.page-breadcrumb{flex-direction:column;align-items:flex-start;gap:8px}.page-breadcrumb .btn{width:100%;justify-content:center}.homolog-stats{flex-direction:column}.homolog-stats-bar{flex-direction:column!important;gap:8px!important}.homolog-action-btns{flex-direction:column!important}.homolog-action-btns button{width:100%}.client-header-card>div{flex-direction:column!important}.client-header-stats{display:grid!important;grid-template-columns:repeat(2,1fr)!important;width:100%}.reports-filter-row{flex-direction:column!important;align-items:stretch!important}.reports-filter-row .form-input,.reports-filter-row select{max-width:100%!important;width:100%!important}.reports-kpi-grid{grid-template-columns:repeat(2,1fr)!important}.donut-chart-wrap{flex-direction:column!important;align-items:center!important}.donut-chart-wrap svg{max-width:140px;height:auto}.reports-overview-grid{grid-template-columns:1fr!important}.reports-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important}.reports-tabs button{flex-shrink:0;white-space:nowrap}.reports-filters-card>div{flex-direction:column!important;align-items:stretch!important}.reports-filters-card select,.reports-filters-card .form-input{max-width:100%!important;width:100%!important}.reports-filters-card .btn{width:100%;justify-content:center}.profile-payments-grid{grid-template-columns:1fr!important}.payment-modal-header{flex-wrap:wrap!important;gap:6px!important}.payment-values-grid{grid-template-columns:1fr!important}.user-hero-pills{flex-wrap:wrap!important;justify-content:center!important;padding:0 8px!important}.user-hero-pills span{max-width:calc(50% - 8px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sla-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.page-actions-row{flex-wrap:wrap!important;gap:8px!important}.page-actions-row .btn{flex:1;min-width:140px;justify-content:center}.barchart-label{max-width:80px!important;width:80px!important}.ticket-detail-grid{grid-template-columns:1fr!important}.contrato-card{overflow-x:hidden}.ticket-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;padding-bottom:2px}.ticket-tabs button{flex-shrink:0;white-space:nowrap}html,body,#root{overflow-x:hidden;max-width:100vw}.card,.modal-box,.app-content,.page-header{max-width:100%;overflow-x:hidden}.card-header,.page-header,.filter-bar,.modal-footer{flex-wrap:wrap}.login-page{flex-direction:column}.login-panel-left{min-height:220px;flex:none;padding:var(--space-8)}.login-left-logo{width:52px;height:52px;font-size:26px}.login-left-title{font-size:22px}.login-panel-right{width:100%;min-width:unset;padding:var(--space-8) var(--space-5)}}@media (max-width: 400px){.stats-grid{grid-template-columns:1fr 1fr!important;gap:var(--space-2)}.stat-value{font-size:18px!important}.stat-label{font-size:11px!important}.stat-card{padding:var(--space-3)!important}.app-content{padding:var(--space-3);padding-bottom:calc(var(--bottom-nav-h) + 12px)}.bottom-nav-label{font-size:9px}}.gantt-wrapper{display:flex;flex-direction:column;min-height:500px;height:calc(100vh - 200px);max-height:860px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;position:relative}.gantt-toolbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);background:var(--color-bg-card);flex-shrink:0;position:sticky;top:0;z-index:20}.gantt-scroll-outer{flex:1;overflow:auto;min-width:0}.gantt-grid{display:grid;grid-template-columns:260px 1fr;min-width:800px}.gantt-divider{position:absolute;bottom:0;width:10px;transform:translate(-50%);cursor:col-resize;z-index:30;background:transparent}.gantt-divider:after{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%);width:2px;background:var(--color-border);transition:background .2s,width .2s;border-radius:2px}.gantt-divider:hover:after,.gantt-divider.dragging:after{width:3px;background:var(--color-primary);box-shadow:0 0 8px #0c5a9d66}.gantt-divider:before{content:"↕";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(90deg);font-size:11px;color:var(--color-primary-400);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:4px;padding:2px 4px;opacity:0;transition:opacity .2s;pointer-events:none;white-space:nowrap;-webkit-user-select:none;user-select:none}.gantt-divider:hover:before{opacity:1}.gantt-header-label{position:sticky;left:0;z-index:15;background:var(--color-bg-card);border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);padding:0 var(--space-4);display:flex;align-items:center;height:38px}.gantt-header-bar{position:relative;background:var(--color-bg-card);border-bottom:1px solid var(--color-border);height:38px}.gantt-months{display:flex;height:100%;width:100%}.gantt-month-label{display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:capitalize;border-right:1px solid var(--color-border);height:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.4px}.gantt-today-line{position:absolute;top:0;bottom:0;width:2px;background:var(--color-primary);opacity:.65;pointer-events:none;z-index:5}.gantt-label-cell{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);padding:0 var(--space-3);overflow:hidden;position:sticky;left:0;z-index:10;background:var(--color-bg-card);gap:var(--space-2);transition:background .15s}.gantt-label-cell:hover{background:var(--color-bg-hover)}.gantt-module-label{background:var(--color-bg-card)}.gantt-event-label{background:var(--color-bg-elevated)}.gantt-event-label:hover{background:var(--color-bg-hover)}.gantt-label-inner{display:flex;align-items:center;gap:6px;flex:1;min-width:0;overflow:hidden}.gantt-chevron{color:var(--color-text-muted);display:flex;align-items:center;flex-shrink:0}.gantt-module-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.gantt-module-title{font-size:13px;font-weight:700;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-event-title{font-size:12px;font-weight:500;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-module-count{flex-shrink:0;font-size:10px;font-weight:700;background:var(--color-primary-light, rgba(12,90,157,.12));color:var(--color-primary-400);border-radius:999px;padding:1px 6px;line-height:1.4}.gantt-approval-dot{width:7px;height:7px;border-radius:50%;background:var(--color-warning);flex-shrink:0;animation:pulse 1.5s ease-in-out infinite}.gantt-actions{display:none;align-items:center;gap:3px;flex-shrink:0}.gantt-label-cell:hover .gantt-actions{display:flex}.gantt-action-btn{width:22px;height:22px;border:none;background:var(--color-bg-hover);border-radius:4px;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);padding:0}.gantt-action-btn:hover{background:var(--color-primary-glow);color:var(--color-primary-400)}.gantt-action-btn.danger:hover{background:var(--color-danger-bg);color:var(--color-danger)}.gantt-bar-cell{border-bottom:1px solid var(--color-border);position:relative;overflow:hidden}.gantt-module-label~.gantt-bar-cell{background:transparent}.gantt-event-label~.gantt-bar-cell{background:#ffffff03}.gantt-bar-label{position:absolute;left:8px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 16px);pointer-events:none}.gantt-tooltip{position:fixed;z-index:9999;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 12px;pointer-events:none;box-shadow:var(--shadow-lg);animation:fadeIn .1s ease;max-width:240px}.gantt-tooltip-title{font-size:13px;font-weight:700;color:var(--color-text);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-tooltip-dates{font-size:11px;color:var(--color-text-muted)}.gantt-tooltip-status{font-size:11px;font-weight:600;color:var(--color-text-subtle);margin-top:4px;padding-top:4px;border-top:1px solid var(--color-border)}.gantt-status-badge{display:inline-flex;align-items:center;flex-shrink:0;font-size:9px;font-weight:700;letter-spacing:.3px;padding:2px 6px;border-radius:4px;white-space:nowrap;text-transform:uppercase}@media (max-width: 768px){.gantt-wrapper{height:auto;min-height:400px;max-height:70vh}}
