.layout{display:flex;min-height:100vh}.sidebar{width:280px;background:var(--aps-sidebar);color:#fff;display:flex;flex-direction:column;flex-shrink:0;box-shadow:4px 0 24px #00000014}.sidebar-brand{padding:1.5rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:.75rem}.logo{font-weight:800;font-size:1.625rem;letter-spacing:-.03em;background:linear-gradient(135deg,#5eead4,#2dd4bf);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-name{font-weight:700;font-size:1rem;letter-spacing:.06em;opacity:.95;color:#f1f5f9}.sidebar-nav{flex:1;padding:1rem .75rem;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:#ffffffc7;border-radius:10px;margin-bottom:2px;transition:all .2s ease;font-weight:500;font-size:.9375rem}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:linear-gradient(135deg,#0d9488e6,#14b8a6d9);color:#fff;box-shadow:0 2px 8px #0d948859}.nav-icon{font-size:1.125rem;opacity:.9}.sidebar-footer{padding:1.25rem 1rem;border-top:1px solid rgba(255,255,255,.06);background:#00000026}.user-info{display:flex;flex-direction:column;margin-bottom:.75rem}.user-name{font-weight:600;font-size:.9rem;color:#f1f5f9}.user-role{font-size:.75rem;opacity:.65;text-transform:capitalize;color:#94a3b8}.btn-logout{width:100%;padding:.625rem 1rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#cbd5e1;font-size:.875rem;font-weight:500;transition:all .2s}.btn-logout:hover{background:#ffffff1a;color:#fff}.main-content{flex:1;padding:2rem 2.5rem;overflow-y:auto;background:linear-gradient(160deg,#f8fafc,#f1f5f9);min-height:100vh}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#0f172a,#1e293b 40%,#0f766e);padding:2rem;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(45,212,191,.15),transparent),radial-gradient(ellipse 60% 40% at 100% 50%,rgba(13,148,136,.1),transparent);pointer-events:none}.login-card{width:100%;max-width:420px;background:#fff;border-radius:24px;box-shadow:0 25px 50px -12px #00000059,0 0 0 1px #ffffff0d;padding:2.75rem;position:relative;z-index:1}.login-header{text-align:center;margin-bottom:2.25rem}.login-title{font-size:1.875rem;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,#0f766e,#14b8a6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{margin-top:.5rem;color:var(--aps-text-muted);font-size:.9375rem;font-weight:500}.login-form label{display:block;margin-bottom:1.25rem;font-weight:600;font-size:.875rem;color:var(--aps-text)}.login-form input{width:100%;margin-top:.375rem;padding:.875rem 1.125rem;border:1px solid var(--aps-border);border-radius:12px;font-size:1rem;background:#fafafa;transition:border-color .2s,box-shadow .2s,background .2s}.login-form input:focus{outline:none;border-color:var(--aps-primary);box-shadow:0 0 0 3px var(--aps-primary-light);background:#fff}.login-error{padding:.875rem 1rem;background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#b91c1c;border-radius:12px;margin-bottom:1rem;font-size:.875rem;font-weight:500;border:1px solid #fecaca}.btn-login{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,var(--aps-primary) 0%,var(--aps-accent) 100%);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;margin-top:.5rem;box-shadow:0 4px 14px #0d948866;transition:box-shadow .2s,transform .15s}.btn-login:hover:not(:disabled){box-shadow:0 6px 20px #0d948873}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-hint{margin-top:1.75rem;font-size:.75rem;color:var(--aps-text-muted);text-align:center;font-weight:500}.dashboard{max-width:1200px;margin:0 auto}.dashboard .page-header h1{font-size:1.75rem;font-weight:800;letter-spacing:-.03em}.dashboard .page-subtitle{font-weight:500}.page-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--aps-text-muted);font-weight:500}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;margin-bottom:2.5rem}.stat-card{background:var(--aps-surface-elevated);border-radius:var(--aps-radius-lg);padding:1.5rem 1.75rem;box-shadow:var(--aps-shadow);border:1px solid var(--aps-border);display:flex;flex-direction:column;gap:.5rem;text-decoration:none;color:inherit;transition:all .25s ease}.stat-card:hover{box-shadow:var(--aps-shadow-lg);border-color:var(--aps-primary-muted);transform:translateY(-2px)}.stat-card--highlight{border-color:var(--aps-primary-muted);background:linear-gradient(135deg,#f0fdfa,#fff 50%);box-shadow:0 4px 14px #0d94881f}.stat-card--highlight:hover{box-shadow:0 8px 24px #0d94882e}.stat-value{font-size:1.875rem;font-weight:800;color:var(--aps-text);letter-spacing:-.02em}.stat-label{font-size:.875rem;color:var(--aps-text-muted);font-weight:500}.dashboard-section{background:var(--aps-surface-elevated);border-radius:var(--aps-radius-lg);padding:1.75rem;border:1px solid var(--aps-border);box-shadow:var(--aps-shadow-sm)}.dashboard-section h2{font-size:1.0625rem;font-weight:700;margin-bottom:1.25rem;color:var(--aps-text);letter-spacing:-.01em}.quick-actions{display:flex;flex-wrap:wrap;gap:.75rem}.quick-action{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--aps-primary) 0%,var(--aps-accent) 100%);color:#fff;border-radius:12px;font-size:.9375rem;font-weight:600;text-decoration:none;box-shadow:0 2px 8px #0d948859;transition:box-shadow .2s,transform .15s}.quick-action:hover{box-shadow:0 4px 14px #0d948866;color:#fff;transform:translateY(-1px)}.announcement-preview{margin-bottom:.875rem;padding:1rem 1.25rem;background:linear-gradient(90deg,var(--aps-primary-light) 0%,#f0fdfa 100%);border-radius:12px;border-left:4px solid var(--aps-primary)}.announcement-preview:last-child{margin-bottom:0}.announcement-preview p{margin:.25rem 0 0;font-size:.9rem;color:var(--aps-text-muted);line-height:1.5}.drawer-backdrop{position:fixed;inset:0;background:#0f172a73;z-index:40;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.detail-drawer{position:fixed;top:0;right:0;width:80%;max-width:960px;height:100vh;background:var(--aps-surface-elevated);box-shadow:-12px 0 48px #0000001f;z-index:50;display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.32,.72,0,1)}@media(max-width:768px){.detail-drawer{width:100%;max-width:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--aps-border);flex-shrink:0;background:linear-gradient(180deg,#fafafa,#fff)}.drawer-title{margin:0;font-size:1.25rem;font-weight:700;color:var(--aps-text);letter-spacing:-.02em}.drawer-close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;background:var(--aps-surface);color:var(--aps-text-muted);font-size:1.5rem;line-height:1;border-radius:10px;transition:all .2s}.drawer-close:hover{background:var(--aps-border);color:var(--aps-text)}.drawer-body{flex:1;overflow-y:auto;padding:2rem}.drawer-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--aps-text-muted);font-weight:500}.detail-section{margin-bottom:2rem}.detail-section:last-child{margin-bottom:0}.detail-section-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--aps-text-muted);margin-bottom:1rem}.detail-grid{display:grid;gap:1rem}.detail-row{display:flex;flex-direction:column;gap:.375rem}.detail-label{font-size:.75rem;color:var(--aps-text-muted);font-weight:500}.detail-value{font-size:.9375rem;font-weight:500;color:var(--aps-text)}.detail-value.muted{font-weight:400;color:var(--aps-text-muted)}.pro-page{max-width:1400px;margin:0 auto}.page-header{margin-bottom:1.75rem}.page-header h1{font-size:1.75rem;font-weight:800;color:var(--aps-text);letter-spacing:-.03em;line-height:1.2}.page-subtitle{margin-top:.375rem;font-size:.9375rem;color:var(--aps-text-muted);font-weight:500}.page-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem}.search-form{display:flex;gap:.5rem;max-width:360px}.search-form input{flex:1;padding:.625rem 1rem;border:1px solid var(--aps-border);border-radius:10px;font-size:.9375rem;background:var(--aps-surface-elevated);transition:border-color .2s,box-shadow .2s}.search-form input:focus{outline:none;border-color:var(--aps-primary);box-shadow:0 0 0 3px var(--aps-primary-light)}.search-form button,.btn-secondary{padding:.625rem 1.25rem;background:var(--aps-secondary);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:600;transition:filter .2s}.search-form button:hover,.btn-secondary:hover{filter:brightness(1.1)}.card-list{background:var(--aps-surface-elevated);border-radius:var(--aps-radius-lg);box-shadow:var(--aps-shadow);border:1px solid var(--aps-border);overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:1rem 1.25rem;text-align:left;border-bottom:1px solid var(--aps-border)}.data-table th{background:linear-gradient(180deg,#f8fafc,#f1f5f9);font-weight:700;font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--aps-text-muted)}.data-table tbody tr{transition:background .15s ease}.data-table tbody tr:hover{background:#fafafa}.data-table tbody tr.clickable{cursor:pointer}.data-table tbody tr.clickable:hover{background:linear-gradient(90deg,var(--aps-primary-light) 0%,transparent 100%)}.table-loading,.table-empty{padding:4rem 2rem;text-align:center;color:var(--aps-text-muted);font-size:.9375rem;font-weight:500}.table-footer{padding:.875rem 1.25rem;font-size:.8125rem;color:var(--aps-text-muted);border-top:1px solid var(--aps-border);background:linear-gradient(180deg,#fafafa,#f8fafc);font-weight:500}.badge{display:inline-block;padding:.3rem .6rem;border-radius:8px;font-size:.75rem;font-weight:600}.badge-success{background:#d1fae5;color:#065f46}.badge-muted{background:#f1f5f9;color:#64748b}.badge-warning{background:#fef3c7;color:#b45309}.badge-danger{background:#fee2e2;color:#b91c1c}.badge-info{background:#dbeafe;color:#1d4ed8}.pagination{display:flex;align-items:center;justify-content:center;gap:1.25rem;margin-top:1.5rem}.pagination button{padding:.5rem 1.25rem;border:1px solid var(--aps-border);background:var(--aps-surface-elevated);border-radius:10px;font-size:.875rem;font-weight:500;transition:all .2s}.pagination button:hover:not(:disabled){background:var(--aps-primary);color:#fff;border-color:var(--aps-primary)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{padding:.625rem 1.25rem;background:linear-gradient(135deg,var(--aps-primary) 0%,var(--aps-accent) 100%);color:#fff;border-radius:10px;font-weight:600;font-size:.875rem;border:none;text-decoration:none;display:inline-flex;align-items:center;gap:.375rem;box-shadow:0 2px 8px #0d948859;transition:box-shadow .2s,transform .15s}.btn-primary:hover{box-shadow:0 4px 12px #0d948866;color:#fff}.btn-link{color:var(--aps-primary);font-size:.875rem;font-weight:600}.btn-link:hover{text-decoration:underline}.drawer-actions{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--aps-border)}.tabs-row{display:flex;gap:.5rem;margin-bottom:1.5rem}.tab-btn{padding:.625rem 1.25rem;border:1px solid var(--aps-border);background:var(--aps-surface-elevated);border-radius:10px;font-weight:600;font-size:.875rem;color:var(--aps-text-muted);transition:all .2s ease}.tab-btn:hover{border-color:var(--aps-primary-muted);color:var(--aps-primary)}.tab-btn.active{background:linear-gradient(135deg,var(--aps-primary) 0%,var(--aps-accent) 100%);color:#fff;border-color:transparent;box-shadow:0 2px 8px #0d948859}.card-list-title{margin:0;padding:1.25rem 1.5rem;font-size:.9375rem;font-weight:700;border-bottom:1px solid var(--aps-border);background:linear-gradient(180deg,#fafafa,#f8fafc);color:var(--aps-text)}.detail-line{display:flex;justify-content:space-between;align-items:center;padding:.625rem 0;border-bottom:1px solid var(--aps-border);font-size:.875rem}.page-header-flex{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem}.drawer-actions{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--aps-border)}.drawer-actions .btn-primary{width:100%;justify-content:center}.client-form-page .form-card{background:#fff;border-radius:12px;border:1px solid var(--aps-border);padding:2rem;max-width:800px}.form-section{margin-bottom:2rem}.form-section h2{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--aps-text);padding-bottom:.5rem;border-bottom:1px solid var(--aps-border)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-grid label.span-2{grid-column:span 2}.form-section label{display:block;margin-bottom:1rem;font-weight:500;font-size:.875rem}.form-section input,.form-section select,.form-section textarea{width:100%;margin-top:.25rem;padding:.5rem .75rem;border:1px solid var(--aps-border);border-radius:6px}.checkbox-label{display:flex;align-items:center;gap:.5rem}.checkbox-label input{width:auto}.form-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--aps-border)}.btn-secondary{padding:.5rem 1rem;background:#fff;border:1px solid var(--aps-border);border-radius:6px;color:var(--aps-text)}.btn-secondary:hover{background:var(--aps-surface)}.tab-btn:hover{background:var(--aps-surface)}.detail-line:last-child{border-bottom:none}.detail-line span:first-child{color:var(--aps-text)}.tabs-row{display:flex;gap:.25rem;margin-bottom:1.25rem}.tab-btn{padding:.5rem 1rem;border:1px solid var(--aps-border);background:#fff;border-radius:8px;font-weight:500;font-size:.875rem}.tab-btn.active{background:var(--aps-primary);color:#fff;border-color:var(--aps-primary)}.acheter-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:900px){.acheter-grid{grid-template-columns:1fr}}.card-list-title{margin:0;padding:1rem 1.25rem;font-size:.9375rem;font-weight:600;border-bottom:1px solid var(--aps-border);background:#fafafa}.detail-line{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--aps-border);font-size:.875rem}.detail-line span:last-child{color:var(--aps-text-muted)}.projets-page small{color:var(--aps-text-muted);font-weight:400}.detail-lines{list-style:none;padding:0;margin:0}.detail-line{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--aps-border);font-size:.875rem}.badge-in_progress{background:#dbeafe;color:#1d4ed8}.badge-answered{background:#d1fae5;color:#065f46}.badge-closed{background:#e2e8f0;color:#475569}.badge-open{background:#fef3c7;color:#b45309}.ticket-replies{display:flex;flex-direction:column;gap:.75rem}.ticket-reply{padding:.75rem;background:#f8fafc;border-radius:8px;border-left:3px solid var(--aps-primary)}.ticket-reply-message{margin:0 0 .25rem;font-size:.9375rem;white-space:pre-wrap}.ticket-reply-date{font-size:.75rem;color:var(--aps-text-muted)}.stages-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.stage-pill{padding:.35rem .75rem;border-radius:999px;border:2px solid;font-size:.8rem;font-weight:500}.prospects-page small{color:var(--aps-text-muted);font-weight:400}.rapports-page .report-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.rapports-page .report-tabs .tab{padding:.5rem 1rem;border:1px solid var(--aps-border);background:#fff;border-radius:8px;font-weight:500}.rapports-page .report-tabs .tab.active{background:var(--aps-primary);color:#fff;border-color:var(--aps-primary)}.rapports-page .report-card{background:#fff;border-radius:12px;border:1px solid var(--aps-border);padding:1.5rem}.rapports-page .report-summary{margin-bottom:1rem;font-size:1rem}.rapports-page .report-summary-block{margin-bottom:1rem;padding:1rem;background:var(--aps-surface);border-radius:8px}.rapports-page .report-summary-block p{margin:.25rem 0}.rapports-page .report-placeholder{padding:2rem;text-align:center;color:var(--aps-text-muted);background:#fff;border-radius:12px;border:1px solid var(--aps-border)}.annonces-page .annonces-list{display:flex;flex-direction:column;gap:1rem}.annonces-page .announcement-card{padding:1.25rem;background:#fff;border-radius:12px;border:1px solid var(--aps-border)}.annonces-page .announcement-card.pinned{border-color:var(--aps-primary);background:linear-gradient(135deg,#f0fdfa,#fff)}.annonces-page .announcement-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.annonces-page .announcement-header h2{margin:0;font-size:1.1rem}.annonces-page .badge-pinned{font-size:.7rem;padding:.2rem .5rem;background:var(--aps-primary);color:#fff;border-radius:4px}.annonces-page .announcement-content{margin:0 0 .5rem;color:var(--aps-text);line-height:1.5}.annonces-page .announcement-date{margin:0;font-size:.8rem;color:var(--aps-text-muted)}.annonces-page .table-empty-card{padding:2rem;text-align:center;color:var(--aps-text-muted)}:root{--aps-primary: #0d9488;--aps-primary-hover: #0f766e;--aps-primary-light: #ccfbf1;--aps-primary-muted: #99f6e4;--aps-accent: #14b8a6;--aps-secondary: #0f172a;--aps-sidebar: linear-gradient(180deg, #0f172a 0%, #1e293b 50%, #0f172a 100%);--aps-surface: #f8fafc;--aps-surface-elevated: #ffffff;--aps-border: #e2e8f0;--aps-border-strong: #cbd5e1;--aps-text: #0f172a;--aps-text-muted: #64748b;--aps-shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--aps-shadow: 0 4px 6px -1px rgba(15, 23, 42, .07), 0 2px 4px -2px rgba(15, 23, 42, .05);--aps-shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, .08), 0 4px 6px -4px rgba(15, 23, 42, .04);--aps-shadow-xl: 0 20px 25px -5px rgba(15, 23, 42, .08), 0 8px 10px -6px rgba(15, 23, 42, .04);--aps-radius: 12px;--aps-radius-lg: 16px;--font-sans: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--aps-surface);color:var(--aps-text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:var(--aps-primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}
