@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";[data-sonner-toaster]{pointer-events:none}[data-sonner-toaster] [data-sonner-toast]{pointer-events:auto}.app-root{isolation:isolate}:root{--font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--color-primary: #4F46E5;--color-primary-dark: #4338CA;--color-primary-light: #818CF8;--color-primary-subtle: #EEF2FF;--color-success: #059669;--color-success-bg: #D1FAE5;--color-warning: #D97706;--color-warning-bg: #FEF3C7;--color-error: #DC2626;--color-error-bg: #FEE2E2;--color-info: #0284C7;--color-info-bg: #E0F2FE;--color-bg: #F8FAFC;--color-surface: #FFFFFF;--color-border: #E2E8F0;--color-border-light: #F1F5F9;--color-text-primary: #0F172A;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-text-inverse: #FFFFFF;--sidebar-bg: #312E81;--sidebar-bg-hover: rgba(79, 70, 229, .25);--sidebar-bg-active: rgba(99, 102, 241, .4);--sidebar-text: rgba(255, 255, 255, .95);--sidebar-text-muted: rgba(255, 255, 255, .65);--sidebar-logout-bg: #1E1B4B;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgb(0 0 0 / .05);--shadow-md: 0 4px 12px rgb(0 0 0 / .08);--shadow-lg: 0 10px 25px rgb(0 0 0 / .1);--shadow-xl: 0 20px 40px rgb(0 0 0 / .12);--shadow-glow: 0 0 0 3px rgb(79 70 229 / .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--ease-out-expo: cubic-bezier(.16, 1, .3, 1)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;touch-action:manipulation}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-family:inherit;font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-fast)}@media(max-width:768px){.btn{min-height:44px;padding:var(--spacing-md) var(--spacing-lg);touch-action:manipulation}.btn-sm{min-height:40px}.btn-lg{min-height:48px}}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-text-inverse);box-shadow:0 2px 8px #4f46e540;transition:all var(--transition-base) var(--ease-out-expo)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark) 0%,#3730A3 100%);transform:translateY(-2px);box-shadow:0 6px 20px #4f46e559}.btn-secondary{background:var(--color-surface);color:var(--color-text-primary);border:1.5px solid var(--color-border);transition:all var(--transition-base) var(--ease-out-expo)}.btn-secondary:hover:not(:disabled){background:var(--color-primary-subtle);border-color:var(--color-primary-light);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-border-light)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background:#047857}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-xs)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-base)}.btn-icon{aspect-ratio:1;padding:var(--spacing-sm)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}@media(max-width:768px){.card{padding:var(--spacing-lg)}}.card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border)}.card-header{padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.card-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-full)}.badge-primary{background:var(--color-primary-subtle);color:var(--color-primary)}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-error{background:var(--color-error-bg);color:var(--color-error)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.input,.textarea,.select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:inherit;font-size:var(--font-size-sm);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}@media(max-width:768px){.input,.textarea,.select{min-height:48px;font-size:16px;touch-action:manipulation}.textarea{min-height:120px}}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-glow)}.input::placeholder,.textarea::placeholder{color:var(--color-text-muted)}.textarea{min-height:100px;resize:vertical}.label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.form-group{margin-bottom:var(--spacing-lg)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}@media(max-width:640px){.form-grid{grid-template-columns:1fr}}.form-error{font-size:var(--font-size-xs);color:var(--color-error);margin-top:var(--spacing-xs)}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.table{width:100%;min-width:400px;border-collapse:collapse;font-size:var(--font-size-sm)}.table th,.table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border-light)}@media(max-width:768px){.table th,.table td{padding:var(--spacing-sm);font-size:var(--font-size-xs)}}.table th{font-weight:600;color:var(--color-text-secondary);background:var(--color-bg)}.table tr:hover td{background:var(--color-primary-subtle)}.page-header,.page-header-custom{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}@media(max-width:768px){.page-header,.page-header-custom{gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}}.page-title{font-size:var(--font-size-2xl);font-weight:800;color:var(--color-text-primary);letter-spacing:-.02em}.page-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}@media(max-width:768px){.page-title{font-size:var(--font-size-xl)}}.filters-bar{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-items:center;margin-bottom:var(--spacing-lg)}.filter-tab{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-full);border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.filter-tab:hover{color:var(--color-primary)}.filter-tab.active{background:var(--color-primary-subtle);color:var(--color-primary)}.loading-state{display:flex;align-items:center;justify-content:center;min-height:200px;padding:var(--spacing-2xl)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-xl);background:var(--color-surface);border-radius:var(--radius-xl);border:1px dashed var(--color-border)}.empty-state svg,.empty-state-icon{opacity:.5;color:var(--color-text-muted);margin:0 auto var(--spacing-md);display:block}.empty-state h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-sm);color:var(--color-text-secondary)}.empty-state p{color:var(--color-text-muted);font-size:var(--font-size-sm);line-height:1.5}.empty-state-action{margin-top:var(--spacing-lg)}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border-radius:var(--radius-2xl);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--spacing-xl);border-bottom:1px solid var(--color-border-light)}.modal-body{padding:var(--spacing-xl)}.modal-footer{padding:var(--spacing-xl);border-top:1px solid var(--color-border-light);display:flex;gap:var(--spacing-md);justify-content:flex-end}.fade-in{animation:fadeIn .4s var(--ease-out-expo) both}.slide-up{animation:slideUp .5s var(--ease-out-expo) both}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:var(--spacing-xl)}.auth-bg{position:fixed;inset:0;z-index:0;pointer-events:none;touch-action:none}.auth-bg-pattern{position:absolute;inset:0;background-image:url(/login_background.jpg);background-size:cover;background-position:center;background-repeat:no-repeat}.auth-bg-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#312e81e0,#4f46e5d1,#4338cae0)}.auth-content{position:relative;z-index:1;width:100%;max-width:520px;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);isolation:isolate}.auth-platform-desc{font-size:var(--font-size-xl);font-weight:700;color:#fff;text-align:center;line-height:1.35;max-width:420px;margin:0;text-shadow:0 2px 12px rgba(0,0,0,.35);letter-spacing:-.01em;animation:authDescEnter .9s cubic-bezier(.16,1,.3,1) both}@keyframes authDescEnter{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.auth-card{display:flex;flex-direction:column;align-items:center;background:#fffffffa;border-radius:var(--radius-2xl);padding:var(--spacing-2xl);box-shadow:var(--shadow-xl);border:1px solid rgba(255,255,255,.3);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);width:100%;min-width:280px;max-width:520px;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:slideUp .4s cubic-bezier(.16,1,.3,1) both}@media(max-width:768px){.auth-card{backdrop-filter:none;-webkit-backdrop-filter:none;background:#fff}}.auth-logo{margin-bottom:var(--spacing-xl);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:opacity var(--transition-fast);flex-shrink:0}.auth-logo:hover{opacity:.9}.auth-logo-img{height:56px;width:auto;max-width:180px;object-fit:contain;object-position:center;display:block}.auth-success-icon{width:80px;height:80px;background:var(--color-success-bg);color:var(--color-success);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-lg)}.auth-title{font-size:var(--font-size-2xl);font-weight:800;margin-bottom:var(--spacing-sm);color:var(--color-text-primary);letter-spacing:-.02em}.auth-subtitle{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xl)}.auth-message{margin-bottom:var(--spacing-md);display:block;text-align:center}.auth-form{margin-bottom:0;width:100%}.auth-card .form-group{width:100%}.auth-link{display:block;margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm)}.auth-submit{width:100%}.auth-footer{margin-top:var(--spacing-xl);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.auth-footer a{font-weight:600;color:var(--color-primary)}.auth-password-wrap{position:relative}.auth-card .input,.auth-card .textarea{min-height:48px;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base)}.auth-password-wrap .input{padding-right:48px}.auth-password-toggle{position:absolute;right:var(--spacing-sm);top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.auth-password-toggle:hover{color:var(--color-primary)}.input[readonly]{background:var(--color-bg);color:var(--color-text-secondary)}.header-dropdown{position:relative}.profile-trigger{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border:none;background:transparent;border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast)}.profile-trigger:hover{background:var(--color-primary-subtle)}.profile-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-sm);flex-shrink:0}.profile-info{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.profile-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-role{font-size:var(--font-size-xs);color:var(--color-text-muted)}.chevron{color:var(--color-text-muted);transition:transform var(--transition-fast)}.chevron.open{transform:rotate(180deg)}.notification-trigger{position:relative;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:var(--radius-lg);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.notification-trigger:hover{background:var(--color-primary-subtle);color:var(--color-primary)}.notification-badge{position:absolute;top:6px;right:6px;min-width:18px;height:18px;background:var(--color-error);color:#fff;font-size:.65rem;font-weight:700;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px}.dropdown-menu{position:absolute;top:calc(100% + var(--spacing-sm));right:0;min-width:260px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--spacing-sm);z-index:100;animation:dropdownSlide .2s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.dropdown-action{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-primary);background:none;border:none;cursor:pointer;border-radius:var(--radius-md);font-family:inherit;white-space:nowrap}.dropdown-action:hover{background:var(--color-primary-subtle)}.dropdown-action:disabled{opacity:.6;cursor:not-allowed}.dropdown-name{display:block;font-weight:600;font-size:var(--font-size-sm)}.dropdown-email{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted)}.dropdown-title{font-weight:600;font-size:var(--font-size-sm)}.dropdown-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);min-height:44px;border:none;background:none;font-family:inherit;font-size:var(--font-size-sm);color:var(--color-text-primary);text-decoration:none;cursor:pointer;border-radius:var(--radius-lg);transition:all var(--transition-fast);text-align:left}.dropdown-item:hover{background:var(--color-primary-subtle)}.dropdown-item.danger{color:var(--color-error)}.dropdown-item.danger:hover{background:var(--color-error-bg)}.dropdown-divider{height:1px;background:var(--color-border-light);margin:var(--spacing-xs) 0}.notifications-menu{min-width:320px;max-height:400px;overflow-y:auto}.notification-item{flex-direction:row}.notification-item div{display:flex;flex-direction:column;gap:2px}.notification-item.unread{background:var(--color-primary-subtle)}.notification-item.unread .notif-desc{font-weight:500;color:var(--color-text-primary)}.notif-title{font-weight:600}.notif-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.notif-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.dropdown-empty{padding:var(--spacing-xl);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.dropdown-footer-link{border-top:1px solid var(--color-border-light);justify-content:center;color:var(--color-primary)!important;font-weight:500}@media(max-width:640px){.profile-info{display:none}.profile-trigger{padding:var(--spacing-sm);min-height:44px}}@media(max-width:768px){.dropdown-menu{max-width:calc(100vw - var(--spacing-lg));right:0;left:auto}.notifications-menu{max-height:70vh}}.app-layout{min-height:100vh;display:grid;grid-template-columns:280px 1fr;grid-template-rows:64px 1fr;grid-template-areas:"sidebar header" "sidebar main";background:var(--color-bg)}.header{grid-area:header;background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 var(--spacing-xl);gap:var(--spacing-lg);position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:var(--spacing-sm);color:var(--color-text-primary);border-radius:var(--radius-lg);transition:background var(--transition-fast)}.menu-toggle:hover{background:var(--color-primary-subtle)}.header-breadcrumb{font-size:var(--font-size-sm);color:var(--color-text-muted)}.header-breadcrumb a{color:var(--color-text-secondary);text-decoration:none}.header-breadcrumb a:hover{color:var(--color-primary)}.header-breadcrumb .crumb-sep{color:var(--color-text-muted)}.header-breadcrumb .crumb-current{color:var(--color-text-primary);font-weight:600}.logo{display:none;align-items:center;gap:var(--spacing-md);text-decoration:none;color:var(--color-text-primary);transition:opacity var(--transition-fast)}.logo:hover{opacity:.9}.logo-img{height:40px;width:auto;object-fit:contain;display:block}.logo-sub{font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary);letter-spacing:.02em}.header-right{margin-left:auto;display:flex;align-items:center;gap:var(--spacing-sm)}.header-auth{display:flex;align-items:center;gap:var(--spacing-sm)}.sidebar{grid-area:sidebar;background:var(--sidebar-bg);padding:var(--spacing-lg) 0;overflow:hidden;display:flex;flex-direction:column;min-height:100vh}.sidebar-scroll{flex:1;min-height:0;overflow-y:auto}.sidebar-brand{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-xl) var(--spacing-xl);border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:var(--spacing-lg);text-decoration:none;transition:opacity var(--transition-fast)}.sidebar-brand:hover{opacity:.95}.sidebar-logo-wrap{flex-shrink:0;width:48px;height:48px;background:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs)}.sidebar-logo{width:100%;height:100%;object-fit:contain;display:block}.sidebar-brand-text{display:flex;flex-direction:column;gap:2px}.sidebar-brand-name{font-size:var(--font-size-lg);font-weight:700;color:#fff;line-height:1.2}.sidebar-tagline{font-size:.65rem;color:var(--sidebar-text-muted);font-weight:600;letter-spacing:.08em;text-transform:uppercase;line-height:1.2}.sidebar-section{padding:0 var(--spacing-md);margin-bottom:var(--spacing-lg)}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:700;color:var(--sidebar-text-muted);letter-spacing:.08em;text-transform:uppercase;padding:var(--spacing-sm) var(--spacing-lg);margin-bottom:var(--spacing-xs)}.nav-items{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);color:var(--sidebar-text);font-weight:500;font-size:var(--font-size-sm);transition:all var(--transition-fast);text-decoration:none;position:relative;border-left:3px solid transparent;margin-left:var(--spacing-md)}.nav-item-text{display:flex;flex-direction:column;gap:2px}.nav-item-desc{font-size:var(--font-size-xs);color:var(--sidebar-text-muted);font-weight:400}.nav-item:hover{background:var(--sidebar-bg-hover);color:#fff}.nav-item.active{background:var(--sidebar-bg-active);color:#fff;border-left-color:var(--color-primary-light)}.nav-item.active:hover{background:var(--sidebar-bg-active)}.nav-item svg{flex-shrink:0;opacity:.9}.nav-badge{margin-left:auto;background:var(--color-primary-light);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-full)}.sidebar-footer{flex-shrink:0;margin-top:0;padding:var(--spacing-lg) var(--spacing-md) 0;border-top:1px solid rgba(255,255,255,.08)}.sidebar-logout{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md) var(--spacing-lg);background:var(--sidebar-logout-bg);border:none;border-radius:var(--radius-lg);color:var(--sidebar-text);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast);text-decoration:none;font-family:inherit;margin-left:var(--spacing-md)}.sidebar-logout:hover{background:#1e1b4be6;color:#fff}.main{grid-area:main;padding:var(--spacing-2xl);overflow-y:auto;animation:fadeIn .3s ease}@media(max-width:1024px){.app-layout{grid-template-columns:260px 1fr}}.sidebar-backdrop{display:none}@media(max-width:768px){.app-layout{grid-template-columns:1fr;grid-template-rows:56px 1fr;grid-template-areas:"header" "main"}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:45;animation:fadeIn .2s ease}.header{padding:0 var(--spacing-md)}.menu-toggle{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px}.logo{display:flex}.header-breadcrumb{display:none}.main{padding:var(--spacing-md)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:min(280px,85vw);max-width:280px;z-index:50;transform:translate(-100%);transition:transform var(--transition-slow);box-shadow:var(--shadow-xl)}.sidebar.open{transform:translate(0)}.nav-item{min-height:48px;padding:var(--spacing-md) var(--spacing-lg)}.sidebar-logout{min-height:48px}}@media(max-width:480px){.main{padding:var(--spacing-sm)}}@supports (padding: env(safe-area-inset-top)){@media(max-width:768px){.header{padding-left:max(var(--spacing-md),env(safe-area-inset-left))}}}.home-page{max-width:960px;margin:0 auto;padding:var(--spacing-lg) 0}.hero{text-align:center;padding:var(--spacing-2xl) 0}.hero-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);background:var(--color-primary-subtle);color:var(--color-primary);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--spacing-lg)}.hero-title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;color:var(--color-text-primary);line-height:1.2;margin-bottom:var(--spacing-md)}.hero-desc{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);max-width:560px;margin-left:auto;margin-right:auto}.hero-actions{display:flex;justify-content:center;gap:var(--spacing-md)}.quick-links{margin-top:var(--spacing-2xl)}.section-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-lg);color:var(--color-text-primary)}.quick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-lg)}.quick-card{display:flex;flex-direction:column;align-items:flex-start;padding:var(--spacing-xl);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);text-decoration:none;color:var(--color-text-primary);transition:all var(--transition-base)}.quick-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-icon{color:var(--color-primary);margin-bottom:var(--spacing-md)}.quick-card span{font-weight:600;margin-bottom:auto}.quick-card svg:last-child{margin-top:var(--spacing-sm);color:var(--color-text-muted);transition:transform var(--transition-fast)}.quick-card:hover svg:last-child{transform:translate(4px);color:var(--color-primary)}.entreprises-page{max-width:1200px;margin:0 auto}.search-bar{display:flex;align-items:center;gap:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-xl);color:var(--color-text-muted);transition:border-color var(--transition-fast)}.search-bar:focus-within{border-color:var(--color-primary);box-shadow:var(--shadow-glow)}.search-bar input:focus{box-shadow:none}.entreprise-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-xl)}.entreprise-card{background:var(--color-surface);border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--color-border);text-decoration:none;color:inherit;transition:all var(--transition-base);display:flex;flex-direction:column}.entreprise-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.entreprise-cover{height:140px;background-size:cover;background-position:center;position:relative}.entreprise-logo{position:absolute;bottom:-24px;left:var(--spacing-lg);width:64px;height:64px;border-radius:var(--radius-lg);object-fit:cover;border:3px solid var(--color-surface);background:var(--color-surface)}.entreprise-body{padding:var(--spacing-xl) var(--spacing-lg) var(--spacing-md);flex:1}.entreprise-body h3{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--spacing-xs)}.entreprise-ville{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.entreprise-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5}.entreprise-footer{padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg);border-top:1px solid var(--color-border-light)}.entreprise-detail-page{max-width:900px;margin:0 auto}.detail-hero{position:relative;height:220px;background-size:cover;background-position:center;border-radius:var(--radius-2xl);margin-bottom:var(--spacing-xl)}.detail-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.6) 100%);border-radius:inherit}.detail-hero-content{position:absolute;bottom:var(--spacing-xl);left:var(--spacing-xl);right:var(--spacing-xl);display:flex;align-items:flex-end;gap:var(--spacing-lg)}.detail-logo{width:80px;height:80px;border-radius:var(--radius-xl);object-fit:cover;border:3px solid white}.detail-hero-content h1{font-size:var(--font-size-2xl);font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.detail-location{display:flex;align-items:center;gap:var(--spacing-sm);color:#ffffffe6;font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.detail-main{display:flex;flex-direction:column;gap:var(--spacing-xl)}.detail-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--spacing-2xl);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.detail-card h2{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.section-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-lg)}.detail-card section+section{margin-top:var(--spacing-2xl)}.detail-card p{color:var(--color-text-secondary);line-height:1.6}.detail-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.stat-badge{background:var(--color-primary-subtle);color:var(--color-primary);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;min-width:140px}.stat-value{font-size:var(--font-size-2xl);font-weight:800}.stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:center}.detail-contact{display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.contact-item{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-sm)}.contact-item:hover{color:var(--color-primary)}.detail-contact-empty{color:var(--color-text-muted);font-size:var(--font-size-sm)}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--spacing-lg)}.portfolio-card{background:var(--color-bg);border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--color-border-light);transition:box-shadow var(--transition-fast)}.portfolio-card:hover{box-shadow:var(--shadow-md)}.portfolio-card-img{width:100%;aspect-ratio:4/3;object-fit:cover}.portfolio-card-body{padding:var(--spacing-lg)}.portfolio-card-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs)}.portfolio-card-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-muted)}.portfolio-card-cat{background:var(--color-primary-subtle);color:var(--color-primary);padding:2px 8px;border-radius:var(--radius-sm)}.portfolio-card-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5;margin:0}.portfolio-sections{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.portfolio-chantier-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.realisation-item-info{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm)}.chantier-nom{font-weight:600;color:var(--color-text-primary);font-size:var(--font-size-xs)}.avant-apres-badge{font-size:var(--font-size-xs);color:var(--color-primary);font-weight:600}.detail-empty-message{color:var(--color-text-muted);font-size:var(--font-size-sm)}.realisations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.realisation-item{aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg)}.realisation-item img{width:100%;height:100%;object-fit:cover}.realisation-item span{display:block;padding:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-muted)}.detail-actions{margin-top:var(--spacing-lg)}.detail-actions-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.detail-actions-grid .btn{flex:1;min-width:200px;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.detail-message-cta{display:inline-flex;flex-direction:column;align-items:center;gap:2px}.detail-message-cta small{font-size:var(--font-size-xs);opacity:.9;font-weight:400}@media(max-width:640px){.realisations-grid{grid-template-columns:repeat(2,1fr)}.detail-actions-grid{flex-direction:column}.detail-actions-grid .btn{min-width:100%}}.demande-devis-page{max-width:700px;margin:0 auto}.demande-form h3{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--spacing-lg);color:var(--color-text-primary)}.devis-page{max-width:900px;margin:0 auto}.devis-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.devis-card{display:block;text-decoration:none;color:inherit;transition:all var(--transition-base)}.devis-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.devis-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.devis-header-badges{display:flex;align-items:center;gap:var(--spacing-xs)}.devis-header-badges .badge{display:inline-flex;align-items:center;gap:4px}.devis-numero{font-weight:600;color:var(--color-primary);font-size:var(--font-size-sm)}.devis-card h3{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.devis-entreprise{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.devis-montant-pending{font-size:var(--font-size-sm);color:var(--color-text-muted);font-style:italic}.devis-montant{font-weight:700;font-size:var(--font-size-lg);color:var(--color-text-primary)}.devis-date{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-sm)}.devis-detail-page{max-width:800px;margin:0 auto}.devis-detail-page .page-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.devis-page-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.devis-page-actions .btn{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.devis-detail-grid{display:flex;flex-direction:column;gap:var(--spacing-xl)}.devis-fichier-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.devis-fichier-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);text-decoration:none}.devis-detail-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.devis-actions{display:flex;gap:var(--spacing-sm)}.devis-section-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--spacing-md);color:var(--color-text-primary)}.devis-entreprise-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.devis-entreprise-nom{font-weight:600;color:var(--color-text-primary);margin:0}.devis-entreprise-contact{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-primary);text-decoration:none;font-size:var(--font-size-sm)}.devis-entreprise-contact:hover{text-decoration:underline}.devis-entreprise-link{align-self:flex-start;margin-top:var(--spacing-xs)}.devis-demande-status{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-md);font-style:italic}.devis-demande-details{display:grid;grid-template-columns:auto 1fr;gap:var(--spacing-xs) var(--spacing-lg);font-size:var(--font-size-sm)}.devis-demande-details dt{color:var(--color-text-muted);font-weight:500}.devis-demande-details dd{margin:0;color:var(--color-text-primary)}.devis-montants-pending{background:var(--color-primary-subtle);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.devis-montants-pending p{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-sm);text-align:center}.devis-montants{background:var(--color-bg);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.montant-row{display:flex;justify-content:space-between;padding:var(--spacing-xs) 0}.montant-row.total{font-weight:700;font-size:var(--font-size-lg);border-top:1px solid var(--color-border);margin-top:var(--spacing-sm);padding-top:var(--spacing-md)}.devis-validite{font-size:var(--font-size-sm);color:var(--color-text-muted)}.lignes-devis{margin-top:var(--spacing-xl)}.lignes-devis h3{margin-bottom:var(--spacing-md)}.factures-page{max-width:900px;margin:0 auto}.factures-resume{display:flex;flex-wrap:wrap;gap:var(--spacing-2xl);margin-bottom:var(--spacing-xl);padding:var(--spacing-xl)}.factures-resume>div{flex:1;min-width:140px}.resume-label{display:block;font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.resume-value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary)}.resume-value.success{color:var(--color-success)}.factures-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.facture-card{display:block;text-decoration:none;color:inherit;transition:all var(--transition-base)}.facture-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.facture-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.facture-numero{font-weight:600;color:var(--color-primary);font-size:var(--font-size-sm)}.facture-entreprise{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.facture-chantier{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.facture-montant{font-weight:700;font-size:var(--font-size-lg);color:var(--color-text-primary)}.facture-date{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.facture-detail-page{max-width:800px;margin:0 auto}.facture-detail-page .page-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.facture-detail-grid{display:flex;flex-direction:column;gap:var(--spacing-xl)}.facture-section-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--spacing-md);color:var(--color-text-primary)}.facture-entreprise-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.facture-entreprise-nom{font-weight:600;color:var(--color-text-primary);margin:0}.facture-entreprise-contact{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-primary);text-decoration:none;font-size:var(--font-size-sm)}.facture-entreprise-contact:hover{text-decoration:underline}.facture-entreprise-adresse{display:flex;align-items:flex-start;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.facture-context-card{display:flex;flex-direction:column;gap:var(--spacing-lg)}.facture-context-item{display:flex;gap:var(--spacing-md);align-items:flex-start}.facture-context-item svg{flex-shrink:0;color:var(--color-primary)}.facture-context-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;font-weight:600;display:block;margin-bottom:2px}.facture-context-item p{margin:0;font-size:var(--font-size-sm)}.facture-context-detail{font-size:var(--font-size-xs);color:var(--color-text-muted);display:block;margin-top:2px}.facture-detail-page .devis-montants{background:var(--color-bg);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.facture-detail-page .montant-row{display:flex;justify-content:space-between;padding:var(--spacing-xs) 0}.facture-detail-page .montant-row.total{font-weight:700;font-size:var(--font-size-lg);border-top:1px solid var(--color-border);margin-top:var(--spacing-sm);padding-top:var(--spacing-md)}.facture-detail-page .montant-paye{color:var(--color-success)}.facture-dates{font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.facture-dates p{margin:0 0 var(--spacing-xs)}.facture-conditions,.facture-notes{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-md) 0 0;padding-top:var(--spacing-md);border-top:1px solid var(--color-border-light)}.chantiers-page{max-width:1000px;margin:0 auto}.chantiers-page .page-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.chantiers-page .page-header .btn{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.chantiers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.chantier-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:all var(--transition-base)}.chantier-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.chantier-progress{margin-bottom:var(--spacing-md)}.progress-bar{height:6px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));border-radius:inherit;transition:width var(--transition-slow)}.progress-text{font-size:var(--font-size-xs);font-weight:600;color:var(--color-primary);margin-top:var(--spacing-xs)}.chantier-card h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm)}.chantier-budget{font-weight:600}.chantier-address{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.chantier-detail-page{max-width:800px;margin:0 auto}.chantier-detail-grid{display:flex;flex-direction:column;gap:var(--spacing-xl)}.chantier-detail-grid .card h3{margin-bottom:var(--spacing-lg);font-size:var(--font-size-lg)}.progress-bar.large{height:12px}.progress-value{font-weight:700;margin-top:var(--spacing-sm);color:var(--color-primary)}.chantier-budgets{display:flex;gap:var(--spacing-xl);margin-top:var(--spacing-lg)}.budget-label{display:block;font-size:var(--font-size-sm);color:var(--color-text-muted)}.budget-value{font-weight:700}.chantier-dates{margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.etapes-timeline{display:flex;flex-direction:column;gap:0}.etape-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-border-light)}.etape-item:last-child{border-bottom:none}.etape-dot{width:12px;height:12px;border-radius:50%;background:var(--color-border);flex-shrink:0;margin-top:4px}.etape-item.done .etape-dot{background:var(--color-success)}.etape-content{flex:1}.etape-content strong{display:block}.etape-progress{font-size:var(--font-size-sm);color:var(--color-primary);margin-left:var(--spacing-sm)}.etape-content p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.journaux-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.journal-item{padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius-lg)}.journal-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.chantier-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-md)}.chantier-photo{border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg)}.chantier-photo img{width:100%;aspect-ratio:1;object-fit:cover}.chantier-photo span{display:block;padding:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-muted)}.messages-page{max-width:1000px;margin:0 auto}.messages-page .empty-state{margin-top:var(--spacing-xl);min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center}.messages-layout{display:grid;grid-template-columns:320px 1fr;min-height:420px;height:70vh;max-height:700px;border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;background:var(--color-surface);box-shadow:var(--shadow-sm)}.conversations-list{border-right:1px solid var(--color-border);overflow-y:auto;max-height:500px}.conversation-item{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:var(--spacing-lg);border:none;background:none;cursor:pointer;text-align:left;border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast);position:relative}.conversation-item:hover{background:var(--color-bg)}.conversation-item.active{background:var(--color-primary-subtle)}.conv-info{display:flex;flex-direction:column;gap:2px}.conv-entreprise{font-size:var(--font-size-xs);color:var(--color-primary)}.conv-address{font-size:var(--font-size-xs);color:var(--color-text-muted)}.conv-preview{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.conv-badge{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:var(--color-primary);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-full)}.messages-panel{display:flex;flex-direction:column;min-height:0;overflow:hidden}.messages-list{flex:1;overflow-y:auto;padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.message-bubble{max-width:75%;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-xl);align-self:flex-start}.message-bubble.sent{align-self:flex-end;background:var(--color-primary);color:#fff;border-bottom-right-radius:4px}.message-bubble.received{background:var(--color-bg);border-bottom-left-radius:4px}.message-bubble p{margin:0}.message-time{font-size:var(--font-size-xs);opacity:.8;margin-top:var(--spacing-xs)}.message-form{display:flex;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;position:sticky;bottom:0;z-index:1}.message-form .input{flex:1;min-width:0}.message-form .btn{display:flex;align-items:center;gap:var(--spacing-xs);white-space:nowrap}.message-form--disabled{opacity:.7}.message-form--disabled .input{background:var(--color-bg);cursor:not-allowed}.messages-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--color-text-muted)}.messages-empty p{margin-top:var(--spacing-md)}.messages-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;color:var(--color-error)}.messages-error-detail{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.messages-empty-hint{align-self:center;color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--spacing-lg)}@media(max-width:768px){.messages-layout{grid-template-columns:1fr}.conversations-list{max-height:200px}}.notifications-page{max-width:720px;margin:0 auto}.notifications-page .page-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.notifications-page .page-header .btn{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.notifications-list{padding:0;overflow:hidden}.notification-row{display:flex;align-items:flex-start;gap:var(--spacing-lg);padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-light);text-decoration:none;color:inherit;transition:background var(--transition-fast)}.notification-row:last-child{border-bottom:none}.notification-row:hover{background:var(--color-bg)}.notification-row.unread,.notification-row.unread:hover{background:var(--color-primary-subtle)}.notification-row.unread .notification-row-content{font-weight:500}.notification-row-icon{flex-shrink:0;width:48px;height:48px;border-radius:var(--radius-lg);background:var(--color-bg);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.notification-row.unread .notification-row-icon{background:var(--color-primary);color:#fff}.notification-row-body{flex:1;min-width:0}.notification-row-content{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.5;margin:0 0 var(--spacing-xs)}.notification-row-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.profil-page{max-width:700px;margin:0 auto}.profil-grid{display:flex;flex-direction:column;gap:var(--spacing-xl)}.profil-page .card h3{margin-bottom:var(--spacing-lg);font-size:var(--font-size-lg)}.form-success{color:var(--color-success);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}html[dir=ltr],[data-sonner-toaster][dir=ltr]{--toast-icon-margin-start: -3px;--toast-icon-margin-end: 4px;--toast-svg-margin-start: -1px;--toast-svg-margin-end: 0px;--toast-button-margin-start: auto;--toast-button-margin-end: 0;--toast-close-button-start: 0;--toast-close-button-end: unset;--toast-close-button-transform: translate(-35%, -35%)}html[dir=rtl],[data-sonner-toaster][dir=rtl]{--toast-icon-margin-start: 4px;--toast-icon-margin-end: -3px;--toast-svg-margin-start: 0px;--toast-svg-margin-end: -1px;--toast-button-margin-start: 0;--toast-button-margin-end: auto;--toast-close-button-start: unset;--toast-close-button-end: 0;--toast-close-button-transform: translate(35%, -35%)}[data-sonner-toaster]{position:fixed;width:var(--width);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;--gray1: hsl(0, 0%, 99%);--gray2: hsl(0, 0%, 97.3%);--gray3: hsl(0, 0%, 95.1%);--gray4: hsl(0, 0%, 93%);--gray5: hsl(0, 0%, 90.9%);--gray6: hsl(0, 0%, 88.7%);--gray7: hsl(0, 0%, 85.8%);--gray8: hsl(0, 0%, 78%);--gray9: hsl(0, 0%, 56.1%);--gray10: hsl(0, 0%, 52.3%);--gray11: hsl(0, 0%, 43.5%);--gray12: hsl(0, 0%, 9%);--border-radius: 8px;box-sizing:border-box;padding:0;margin:0;list-style:none;outline:none;z-index:999999999;transition:transform .4s ease}@media(hover:none)and (pointer:coarse){[data-sonner-toaster][data-lifted=true]{transform:none}}[data-sonner-toaster][data-x-position=right]{right:var(--offset-right)}[data-sonner-toaster][data-x-position=left]{left:var(--offset-left)}[data-sonner-toaster][data-x-position=center]{left:50%;transform:translate(-50%)}[data-sonner-toaster][data-y-position=top]{top:var(--offset-top)}[data-sonner-toaster][data-y-position=bottom]{bottom:var(--offset-bottom)}[data-sonner-toast]{--y: translateY(100%);--lift-amount: calc(var(--lift) * var(--gap));z-index:var(--z-index);position:absolute;opacity:0;transform:var(--y);touch-action:none;transition:transform .4s,opacity .4s,height .4s,box-shadow .2s;box-sizing:border-box;outline:none;overflow-wrap:anywhere}[data-sonner-toast][data-styled=true]{padding:16px;background:var(--normal-bg);border:1px solid var(--normal-border);color:var(--normal-text);border-radius:var(--border-radius);box-shadow:0 4px 12px #0000001a;width:var(--width);font-size:13px;display:flex;align-items:center;gap:6px}[data-sonner-toast]:focus-visible{box-shadow:0 4px 12px #0000001a,0 0 0 2px #0003}[data-sonner-toast][data-y-position=top]{top:0;--y: translateY(-100%);--lift: 1;--lift-amount: calc(1 * var(--gap))}[data-sonner-toast][data-y-position=bottom]{bottom:0;--y: translateY(100%);--lift: -1;--lift-amount: calc(var(--lift) * var(--gap))}[data-sonner-toast][data-styled=true] [data-description]{font-weight:400;line-height:1.4;color:#3f3f3f}[data-rich-colors=true][data-sonner-toast][data-styled=true] [data-description]{color:inherit}[data-sonner-toaster][data-sonner-theme=dark] [data-description]{color:#e8e8e8}[data-sonner-toast][data-styled=true] [data-title]{font-weight:500;line-height:1.5;color:inherit}[data-sonner-toast][data-styled=true] [data-icon]{display:flex;height:16px;width:16px;position:relative;justify-content:flex-start;align-items:center;flex-shrink:0;margin-left:var(--toast-icon-margin-start);margin-right:var(--toast-icon-margin-end)}[data-sonner-toast][data-promise=true] [data-icon]>svg{opacity:0;transform:scale(.8);transform-origin:center;animation:sonner-fade-in .3s ease forwards}[data-sonner-toast][data-styled=true] [data-icon]>*{flex-shrink:0}[data-sonner-toast][data-styled=true] [data-icon] svg{margin-left:var(--toast-svg-margin-start);margin-right:var(--toast-svg-margin-end)}[data-sonner-toast][data-styled=true] [data-content]{display:flex;flex-direction:column;gap:2px}[data-sonner-toast][data-styled=true] [data-button]{border-radius:4px;padding-left:8px;padding-right:8px;height:24px;font-size:12px;color:var(--normal-bg);background:var(--normal-text);margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end);border:none;font-weight:500;cursor:pointer;outline:none;display:flex;align-items:center;flex-shrink:0;transition:opacity .4s,box-shadow .2s}[data-sonner-toast][data-styled=true] [data-button]:focus-visible{box-shadow:0 0 0 2px #0006}[data-sonner-toast][data-styled=true] [data-button]:first-of-type{margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end)}[data-sonner-toast][data-styled=true] [data-cancel]{color:var(--normal-text);background:#00000014}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast][data-styled=true] [data-cancel]{background:#ffffff4d}[data-sonner-toast][data-styled=true] [data-close-button]{position:absolute;left:var(--toast-close-button-start);right:var(--toast-close-button-end);top:0;height:20px;width:20px;display:flex;justify-content:center;align-items:center;padding:0;color:var(--gray12);background:var(--normal-bg);border:1px solid var(--gray4);transform:var(--toast-close-button-transform);border-radius:50%;cursor:pointer;z-index:1;transition:opacity .1s,background .2s,border-color .2s}[data-sonner-toast][data-styled=true] [data-close-button]:focus-visible{box-shadow:0 4px 12px #0000001a,0 0 0 2px #0003}[data-sonner-toast][data-styled=true] [data-disabled=true]{cursor:not-allowed}[data-sonner-toast][data-styled=true]:hover [data-close-button]:hover{background:var(--gray2);border-color:var(--gray5)}[data-sonner-toast][data-swiping=true]:before{content:"";position:absolute;left:-100%;right:-100%;height:100%;z-index:-1}[data-sonner-toast][data-y-position=top][data-swiping=true]:before{bottom:50%;transform:scaleY(3) translateY(50%)}[data-sonner-toast][data-y-position=bottom][data-swiping=true]:before{top:50%;transform:scaleY(3) translateY(-50%)}[data-sonner-toast][data-swiping=false][data-removed=true]:before{content:"";position:absolute;inset:0;transform:scaleY(2)}[data-sonner-toast][data-expanded=true]:after{content:"";position:absolute;left:0;height:calc(var(--gap) + 1px);bottom:100%;width:100%}[data-sonner-toast][data-mounted=true]{--y: translateY(0);opacity:1}[data-sonner-toast][data-expanded=false][data-front=false]{--scale: var(--toasts-before) * .05 + 1;--y: translateY(calc(var(--lift-amount) * var(--toasts-before))) scale(calc(-1 * var(--scale)));height:var(--front-toast-height)}[data-sonner-toast]>*{transition:opacity .4s}[data-sonner-toast][data-x-position=right]{right:0}[data-sonner-toast][data-x-position=left]{left:0}[data-sonner-toast][data-expanded=false][data-front=false][data-styled=true]>*{opacity:0}[data-sonner-toast][data-visible=false]{opacity:0;pointer-events:none}[data-sonner-toast][data-mounted=true][data-expanded=true]{--y: translateY(calc(var(--lift) * var(--offset)));height:var(--initial-height)}[data-sonner-toast][data-removed=true][data-front=true][data-swipe-out=false]{--y: translateY(calc(var(--lift) * -100%));opacity:0}[data-sonner-toast][data-removed=true][data-front=false][data-swipe-out=false][data-expanded=true]{--y: translateY(calc(var(--lift) * var(--offset) + var(--lift) * -100%));opacity:0}[data-sonner-toast][data-removed=true][data-front=false][data-swipe-out=false][data-expanded=false]{--y: translateY(40%);opacity:0;transition:transform .5s,opacity .2s}[data-sonner-toast][data-removed=true][data-front=false]:before{height:calc(var(--initial-height) + 20%)}[data-sonner-toast][data-swiping=true]{transform:var(--y) translateY(var(--swipe-amount-y, 0px)) translate(var(--swipe-amount-x, 0px));transition:none}[data-sonner-toast][data-swiped=true]{-webkit-user-select:none;user-select:none}[data-sonner-toast][data-swipe-out=true][data-y-position=bottom],[data-sonner-toast][data-swipe-out=true][data-y-position=top]{animation-duration:.2s;animation-timing-function:ease-out;animation-fill-mode:forwards}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=left]{animation-name:swipe-out-left}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=right]{animation-name:swipe-out-right}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=up]{animation-name:swipe-out-up}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=down]{animation-name:swipe-out-down}@keyframes swipe-out-left{0%{transform:var(--y) translate(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translate(calc(var(--swipe-amount-x) - 100%));opacity:0}}@keyframes swipe-out-right{0%{transform:var(--y) translate(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translate(calc(var(--swipe-amount-x) + 100%));opacity:0}}@keyframes swipe-out-up{0%{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) - 100%));opacity:0}}@keyframes swipe-out-down{0%{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) + 100%));opacity:0}}@media(max-width:600px){[data-sonner-toaster]{position:fixed;right:var(--mobile-offset-right);left:var(--mobile-offset-left);width:100%}[data-sonner-toaster][dir=rtl]{left:calc(var(--mobile-offset-left) * -1)}[data-sonner-toaster] [data-sonner-toast]{left:0;right:0;width:calc(100% - var(--mobile-offset-left) * 2)}[data-sonner-toaster][data-x-position=left]{left:var(--mobile-offset-left)}[data-sonner-toaster][data-y-position=bottom]{bottom:var(--mobile-offset-bottom)}[data-sonner-toaster][data-y-position=top]{top:var(--mobile-offset-top)}[data-sonner-toaster][data-x-position=center]{left:var(--mobile-offset-left);right:var(--mobile-offset-right);transform:none}}[data-sonner-toaster][data-sonner-theme=light]{--normal-bg: #fff;--normal-border: var(--gray4);--normal-text: var(--gray12);--success-bg: hsl(143, 85%, 96%);--success-border: hsl(145, 92%, 87%);--success-text: hsl(140, 100%, 27%);--info-bg: hsl(208, 100%, 97%);--info-border: hsl(221, 91%, 93%);--info-text: hsl(210, 92%, 45%);--warning-bg: hsl(49, 100%, 97%);--warning-border: hsl(49, 91%, 84%);--warning-text: hsl(31, 92%, 45%);--error-bg: hsl(359, 100%, 97%);--error-border: hsl(359, 100%, 94%);--error-text: hsl(360, 100%, 45%)}[data-sonner-toaster][data-sonner-theme=light] [data-sonner-toast][data-invert=true]{--normal-bg: #000;--normal-border: hsl(0, 0%, 20%);--normal-text: var(--gray1)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast][data-invert=true]{--normal-bg: #fff;--normal-border: var(--gray3);--normal-text: var(--gray12)}[data-sonner-toaster][data-sonner-theme=dark]{--normal-bg: #000;--normal-bg-hover: hsl(0, 0%, 12%);--normal-border: hsl(0, 0%, 20%);--normal-border-hover: hsl(0, 0%, 25%);--normal-text: var(--gray1);--success-bg: hsl(150, 100%, 6%);--success-border: hsl(147, 100%, 12%);--success-text: hsl(150, 86%, 65%);--info-bg: hsl(215, 100%, 6%);--info-border: hsl(223, 43%, 17%);--info-text: hsl(216, 87%, 65%);--warning-bg: hsl(64, 100%, 6%);--warning-border: hsl(60, 100%, 9%);--warning-text: hsl(46, 87%, 65%);--error-bg: hsl(358, 76%, 10%);--error-border: hsl(357, 89%, 16%);--error-text: hsl(358, 100%, 81%)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast] [data-close-button]{background:var(--normal-bg);border-color:var(--normal-border);color:var(--normal-text)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast] [data-close-button]:hover{background:var(--normal-bg-hover);border-color:var(--normal-border-hover)}[data-rich-colors=true][data-sonner-toast][data-type=success],[data-rich-colors=true][data-sonner-toast][data-type=success] [data-close-button]{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}[data-rich-colors=true][data-sonner-toast][data-type=info],[data-rich-colors=true][data-sonner-toast][data-type=info] [data-close-button]{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}[data-rich-colors=true][data-sonner-toast][data-type=warning],[data-rich-colors=true][data-sonner-toast][data-type=warning] [data-close-button]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}[data-rich-colors=true][data-sonner-toast][data-type=error],[data-rich-colors=true][data-sonner-toast][data-type=error] [data-close-button]{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.sonner-loading-wrapper{--size: 16px;height:var(--size);width:var(--size);position:absolute;inset:0;z-index:10}.sonner-loading-wrapper[data-visible=false]{transform-origin:center;animation:sonner-fade-out .2s ease forwards}.sonner-spinner{position:relative;top:50%;left:50%;height:var(--size);width:var(--size)}.sonner-loading-bar{animation:sonner-spin 1.2s linear infinite;background:var(--gray11);border-radius:6px;height:8%;left:-10%;position:absolute;top:-3.9%;width:24%}.sonner-loading-bar:nth-child(1){animation-delay:-1.2s;transform:rotate(.0001deg) translate(146%)}.sonner-loading-bar:nth-child(2){animation-delay:-1.1s;transform:rotate(30deg) translate(146%)}.sonner-loading-bar:nth-child(3){animation-delay:-1s;transform:rotate(60deg) translate(146%)}.sonner-loading-bar:nth-child(4){animation-delay:-.9s;transform:rotate(90deg) translate(146%)}.sonner-loading-bar:nth-child(5){animation-delay:-.8s;transform:rotate(120deg) translate(146%)}.sonner-loading-bar:nth-child(6){animation-delay:-.7s;transform:rotate(150deg) translate(146%)}.sonner-loading-bar:nth-child(7){animation-delay:-.6s;transform:rotate(180deg) translate(146%)}.sonner-loading-bar:nth-child(8){animation-delay:-.5s;transform:rotate(210deg) translate(146%)}.sonner-loading-bar:nth-child(9){animation-delay:-.4s;transform:rotate(240deg) translate(146%)}.sonner-loading-bar:nth-child(10){animation-delay:-.3s;transform:rotate(270deg) translate(146%)}.sonner-loading-bar:nth-child(11){animation-delay:-.2s;transform:rotate(300deg) translate(146%)}.sonner-loading-bar:nth-child(12){animation-delay:-.1s;transform:rotate(330deg) translate(146%)}@keyframes sonner-fade-in{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes sonner-fade-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8)}}@keyframes sonner-spin{0%{opacity:1}to{opacity:.15}}@media(prefers-reduced-motion){[data-sonner-toast],[data-sonner-toast]>*,.sonner-loading-bar{transition:none!important;animation:none!important}}.sonner-loader{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transform-origin:center;transition:opacity .2s,transform .2s}.sonner-loader[data-visible=false]{opacity:0;transform:scale(.8) translate(-50%,-50%)}
