:root{--primary:#2196f3;--primary-dark:#1976d2;--primary-light:#2196f326;--success:#4caf50;--danger:#ef5350;--warning:#ffc107;--bg:#0a0a0a;--bg-card:#1a1a1a;--bg-card-hover:#222;--bg-input:#1e1e1e;--text:#e0e0e0;--text-light:#888;--text-white:#fff;--border:#2a2a2a;--shadow:0 4px 16px #0006;--radius:14px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{max-width:100%;min-height:100dvh}.app{min-height:100dvh;padding-bottom:80px}button{cursor:pointer;border:none;font-family:inherit;font-size:14px}.btn-primary{background:var(--primary);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:10px;padding:12px 24px;font-size:15px;font-weight:700;transition:background .2s,transform .1s}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px 20px;font-weight:600}.btn-small{text-transform:uppercase;letter-spacing:.3px;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:700}.btn-take{background:var(--primary);color:#fff}.btn-edit{color:var(--primary);background:#2196f333}.btn-delete{color:var(--danger);background:#ef535026}.btn-small svg,.btn-primary svg,.btn-logout svg{vertical-align:-2px;margin-right:4px}.btn-logout{color:var(--danger);border-top:1px solid var(--border);background:0 0;width:100%;margin-top:24px;padding:14px;font-weight:600}.page{padding:20px 16px;padding-top:calc(env(safe-area-inset-top,20px) + 16px);max-width:600px;margin:0 auto}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-header h2{color:var(--text-white);text-transform:uppercase;letter-spacing:-.3px;font-size:26px;font-weight:800}.page-banner{border-radius:var(--radius);border:1px solid var(--border);background:linear-gradient(135deg,#1a1a1a 0%,#2a2a2a 50%,#1a1a1a 100%);margin-bottom:20px;padding:20px;position:relative;overflow:hidden}.page-banner:before{content:"";background:linear-gradient(135deg,#0000 0%,#2196f31a 100%);width:120px;height:100%;position:absolute;top:0;right:0}.page-banner .chevrons{color:var(--primary);letter-spacing:-4px;opacity:.6;font-size:24px;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.banner-title{text-transform:uppercase;letter-spacing:2px;color:var(--primary);margin-bottom:4px;font-size:11px;font-weight:700}.banner-subtitle{color:var(--text-white);text-transform:uppercase;font-size:18px;font-weight:800}.filters,.tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;margin-bottom:16px;display:flex;overflow-x:auto}.filters::-webkit-scrollbar{display:none}.tabs::-webkit-scrollbar{display:none}.filter-btn,.tab-btn{background:var(--bg-card);color:var(--text-light);white-space:nowrap;border:1px solid var(--border);border-radius:8px;padding:8px 18px;font-size:13px;font-weight:600;transition:all .2s}.filter-btn.active,.tab-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.courses-list{flex-direction:column;gap:12px;display:flex}.course-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:16px;transition:border-color .2s}.course-card:active{border-color:var(--primary)}.course-card.own-course{border-left:4px solid var(--primary)}.course-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.course-type{text-transform:uppercase;letter-spacing:.5px;border-radius:6px;padding:4px 12px;font-size:11px;font-weight:800}.type-AS{color:#66bb6a;background:#4caf5026}.type-AR{color:var(--primary);background:#2196f333}.type-RS{color:#ffa726;background:#ff980026}.course-date{color:var(--text-light);font-size:13px;font-weight:500}.course-patient{color:var(--text-white);margin-bottom:10px;font-size:16px;font-weight:700}.course-trajet{align-items:center;gap:8px;margin-bottom:10px;font-size:14px;display:flex}.course-lieu{flex:1;align-items:center;gap:6px;display:flex}.lieu-icon{font-size:16px}.course-arrow{color:var(--primary);flex-shrink:0;font-size:16px;font-weight:700}.course-horaires{color:var(--text-light);gap:20px;margin-bottom:10px;font-size:13px;display:flex}.course-horaires strong{color:var(--text-white)}.course-notes{color:var(--text-light);border-left:3px solid var(--border);background:#ffffff08;border-radius:8px;margin-bottom:10px;padding:8px 12px;font-size:13px;font-style:italic}.course-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:12px;display:flex}.course-auteur{color:var(--text-light);font-size:12px}.course-actions{gap:8px;display:flex}.empty-state{text-align:center;color:var(--text-light);padding:60px 16px}.course-form,.profil-form{flex-direction:column;gap:16px;margin-top:16px;display:flex}.course-form label,.profil-form label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;flex-direction:column;gap:6px;font-size:12px;font-weight:700;display:flex}.course-form input,.course-form select,.course-form textarea,.profil-form input{border:1px solid var(--border);background:var(--bg-input);color:var(--text-white);border-radius:10px;padding:14px;font-family:inherit;font-size:16px;transition:border-color .2s}.course-form input:focus,.course-form select:focus,.course-form textarea:focus,.profil-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.course-form select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.form-actions{gap:12px;margin-top:8px;display:flex}.form-actions button{flex:1}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle at 30% 20%,#2196f314 0%,#0000 50%),radial-gradient(circle at 70% 80%,#2196f30d 0%,#0000 50%);width:200%;height:200%;position:absolute;top:-50%;left:-50%}.login-card{background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:380px;box-shadow:var(--shadow);text-align:center;border-radius:20px;padding:40px 28px;position:relative}.login-logo{margin-bottom:8px;font-size:48px}.login-card h1{color:var(--text-white);text-transform:uppercase;margin-bottom:4px;font-size:28px;font-weight:800}.login-subtitle{color:var(--text-light);text-transform:uppercase;letter-spacing:1px;margin-bottom:28px;font-size:13px}.login-card form{flex-direction:column;gap:12px;display:flex}.login-card input{border:1px solid var(--border);background:var(--bg-input);color:var(--text-white);border-radius:10px;padding:14px 16px;font-family:inherit;font-size:16px}.login-card input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.login-card input::placeholder{color:var(--text-light)}.login-card button[type=submit]{background:var(--primary);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:10px;margin-top:8px;padding:14px;font-size:15px;font-weight:700;transition:background .2s,transform .1s}.login-card button[type=submit]:hover{background:var(--primary-dark)}.login-card button[type=submit]:active{transform:scale(.97)}.login-version{color:var(--text-light);margin-bottom:24px;font-size:12px}.toggle-auth{color:var(--primary);cursor:pointer;margin-top:20px;font-size:14px;font-weight:600}.error-msg{color:var(--danger);background:#ef53501f;border:1px solid #ef535033;border-radius:8px;margin-bottom:8px;padding:10px;font-size:14px}.group-tabs{border:1px solid var(--border);border-radius:10px;gap:0;margin-bottom:20px;display:flex;overflow:hidden}.group-tab{background:var(--bg-input);color:var(--text-light);flex:1;padding:12px 16px;font-size:14px;font-weight:600;transition:all .2s}.group-tab.active{background:var(--primary);color:#fff}.messages-page{flex-direction:column;height:calc(100dvh - 80px);padding-bottom:0;display:flex}.messages-container{flex-direction:column;flex:1;min-height:0;display:flex}.messages-list{flex-direction:column;flex:1;gap:8px;padding:8px 0;display:flex;overflow-y:auto}.message{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;align-self:flex-start;max-width:80%;padding:12px 16px}.message.own{background:var(--primary);color:#fff;border-color:var(--primary);align-self:flex-end}.message.own .message-time{color:#fff9}.message-sender{color:var(--primary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px;font-size:12px;font-weight:700;display:block}.message-text{word-break:break-word;font-size:15px;line-height:1.4}.message-time{color:var(--text-light);text-align:right;margin-top:4px;font-size:11px}.message-form{border-top:1px solid var(--border);gap:8px;padding:12px 0;display:flex}.message-form input{border:1px solid var(--border);background:var(--bg-input);color:var(--text-white);border-radius:24px;flex:1;padding:12px 18px;font-family:inherit;font-size:15px}.message-form input:focus{border-color:var(--primary);outline:none}.message-form button{background:var(--primary);color:#fff;text-transform:uppercase;border-radius:24px;padding:12px 20px;font-size:13px;font-weight:700}.message-form button:disabled{opacity:.4}.profil-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);text-align:center;margin-top:16px;padding:32px 24px}.profil-avatar{background:var(--primary);color:#fff;border:3px solid #2196f34d;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 16px;font-size:34px;font-weight:800;display:flex}.profil-info h3{color:var(--text-white);margin-bottom:4px;font-size:22px;font-weight:700}.profil-info p{color:var(--text-light);margin-bottom:4px;font-size:14px}.profil-info .btn-secondary{margin-top:16px}.navbar{border-top:1px solid var(--border);padding:8px 0;padding-bottom:max(8px, env(safe-area-inset-bottom));z-index:100;background:#111;justify-content:space-around;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-light);flex-direction:column;align-items:center;gap:3px;padding:4px 12px;font-size:11px;font-weight:600;text-decoration:none;transition:color .2s;display:flex}.nav-item .nav-icon{font-size:20px}.nav-item .nav-label{font-size:10px}.nav-item.active{color:var(--primary)}.toast-container{top:calc(env(safe-area-inset-top,20px) + 80px);z-index:999;flex-direction:column;gap:8px;display:flex;position:fixed;left:12px;right:12px}.toast{border-left:5px solid var(--primary);border:1px solid var(--border);background:#1e1e1e;border-radius:12px;align-items:center;gap:12px;padding:16px;transition:opacity .3s,transform .3s;animation:.4s ease-out slideDown;display:flex;box-shadow:0 8px 32px #00000080}.toast.hide{opacity:0;transform:translate(100%)}.toast-icon{flex-shrink:0;font-size:30px}.toast-content{flex:1}.toast-content strong{color:var(--text-white);margin-bottom:3px;font-size:14px;font-weight:700;display:block}.toast-content p{color:var(--text-light);font-size:13px;line-height:1.3}.toast-close{color:var(--text-light);background:0 0;flex-shrink:0;align-self:flex-start;padding:4px 8px;font-size:18px}@keyframes slideDown{0%{opacity:0;transform:translateY(-40px)}to{opacity:1;transform:translateY(0)}}.search-bar{background:var(--bg-input);border:1px solid var(--border);border-radius:10px;align-items:center;gap:10px;margin-bottom:16px;padding:10px 16px;display:flex}.search-bar .search-icon{opacity:.5;font-size:16px}.search-bar input{color:var(--text-white);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:15px}.search-bar input::placeholder{color:var(--text-light)}.chauffeurs-list{flex-direction:column;gap:2px;display:flex}.chauffeur-item{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:12px;align-items:center;gap:14px;margin-bottom:8px;padding:14px 16px;transition:border-color .2s,background .2s;display:flex}.chauffeur-item:active{border-color:var(--primary);background:var(--bg-card-hover)}.chauffeur-me{border-left:4px solid var(--primary)}.chauffeur-avatar-small{background:var(--bg-input);border:2px solid var(--border);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;overflow:hidden}.chauffeur-avatar-small img{object-fit:cover;width:100%;height:100%}.chauffeur-avatar-small span{color:var(--primary);font-size:20px;font-weight:800}.chauffeur-info-row{flex:1;min-width:0}.chauffeur-societe{color:var(--primary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.chauffeur-name{color:var(--text-white);font-size:16px;font-weight:700}.chauffeur-phone{color:var(--text-light);margin-top:1px;font-size:13px}.chauffeur-arrow{color:var(--text-light);flex-shrink:0;font-size:24px}.chauffeur-detail-page{padding-top:0!important}.chauffeur-banner{padding:calc(env(safe-area-inset-top,20px) + 16px) 16px 24px;background:linear-gradient(135deg,#1a1a1a 0%,#1a2030 50%,#1a1a1a 100%);margin:0 -16px;position:relative;overflow:hidden}.chauffeur-banner:after{content:"";background:var(--primary);height:4px;position:absolute;bottom:0;left:0;right:0}.back-btn{color:var(--text-white);z-index:2;background:#ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex;position:relative}.banner-stripe{align-items:center;gap:8px;display:flex;position:absolute;top:50%;right:20px;transform:translateY(-50%)}.stripe-text{color:var(--primary);text-transform:uppercase;letter-spacing:3px;opacity:.3;font-size:28px;font-weight:900}.stripe-chevrons{color:var(--primary);opacity:.4;letter-spacing:-3px;font-size:22px}.chauffeur-profile-section{border-bottom:1px solid var(--border);align-items:center;gap:18px;margin-bottom:20px;padding:24px 0 20px;display:flex}.chauffeur-avatar-large{background:var(--bg-input);border:3px solid var(--primary);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;display:flex;overflow:hidden;box-shadow:0 4px 16px #2196f333}.chauffeur-avatar-large img{object-fit:cover;width:100%;height:100%}.chauffeur-avatar-large span{color:var(--primary);font-size:34px;font-weight:800}.chauffeur-identity h2{color:var(--text-white);margin-bottom:2px;font-size:22px;font-weight:800}.chauffeur-societe-detail{color:var(--primary);font-size:14px;font-weight:600}.chauffeur-phone-detail{color:var(--text-light);margin-top:4px;font-size:14px}.chauffeur-section{margin-bottom:24px}.section-title{color:var(--text-white);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:14px;font-weight:700}.info-table{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}.info-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-light);font-size:14px}.info-value{color:var(--text-white);text-align:right;font-size:14px;font-weight:600}.contact-actions{gap:12px;display:flex}.contact-btn{border-radius:var(--radius);border:1px solid var(--border);flex-direction:column;flex:1;align-items:center;gap:8px;padding:18px 12px;font-size:13px;font-weight:700;text-decoration:none;transition:transform .1s;display:flex}.contact-btn:active{transform:scale(.95)}.contact-icon{font-size:26px}.contact-call{color:#66bb6a;background:#4caf501a;border-color:#4caf5033}.contact-sms{color:var(--primary);background:#2196f31a;border-color:#2196f333}.contact-email{color:#ffc107;background:#ffc1071a;border-color:#ffc10733}.profil-avatar-wrapper{cursor:pointer;border-radius:50%;width:90px;height:90px;margin:0 auto 16px;position:relative;overflow:hidden}.profil-avatar-img{object-fit:cover;border:3px solid var(--primary);border-radius:50%;width:100%;height:100%}.profil-avatar-overlay{background:#00000080;border-radius:50%;justify-content:center;align-items:center;font-size:28px;display:flex;position:absolute;inset:0}.profil-societe{color:var(--primary)!important;font-size:15px!important;font-weight:600!important}.accueil-page{padding-top:0!important}.accueil-hero{background:linear-gradient(#0a0f18 0%,#0d1120 40%,#0f1524 100%);height:280px;margin:0 -16px;position:relative;overflow:hidden}.hero-sky{position:absolute;inset:0}.star{background:#fff;border-radius:50%;width:2px;height:2px;animation:3s ease-in-out infinite twinkle;position:absolute}.star-1{animation-delay:0s;top:12%;left:15%}.star-2{width:3px;height:3px;animation-delay:.7s;top:8%;left:45%}.star-3{animation-delay:1.2s;top:20%;left:72%}.star-4{animation-delay:.3s;top:5%;left:88%}.star-5{width:1px;height:1px;animation-delay:1.8s;top:25%;left:30%}.star-6{animation-delay:2.1s;top:15%;left:60%}.star-7{width:1px;height:1px;animation-delay:.9s;top:30%;left:10%}.star-8{animation-delay:1.5s;top:10%;left:95%}@keyframes twinkle{0%,to{opacity:.3}50%{opacity:1}}.hero-abstract{position:absolute;inset:0;overflow:hidden}.abs-skyline{opacity:.12;align-items:flex-end;gap:3px;height:120px;padding:0 10px;display:flex;position:absolute;bottom:35%;left:0;right:0}.building{background:var(--primary);border-radius:2px 2px 0 0;flex-shrink:0}.b1{width:12px;height:35px}.b2{width:8px;height:55px}.b3{width:15px;height:80px}.b4{width:10px;height:45px}.b5{width:6px;height:30px}.b6{width:18px;height:95px}.b7{width:8px;height:50px}.b8{width:14px;height:70px}.b9{width:10px;height:40px}.b10{width:20px;height:110px}.b11{width:7px;height:60px}.b12{width:12px;height:45px}.building:after{content:"";background-image:linear-gradient(0deg,#0000 3px,#ffffff26 3px 4px,#0000 4px);background-size:100% 8px;width:100%;height:100%;display:block}.abs-grid{transform-origin:bottom;background-color:#0000;background-image:linear-gradient(0deg,#2196f314 1px,#0000 1px),linear-gradient(90deg,#2196f30d 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:30px 16px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;height:35%;position:absolute;bottom:0;left:-20%;right:-20%;transform:perspective(150px)rotateX(45deg);-webkit-mask-image:linear-gradient(#0000 10%,#00000080 100%);mask-image:linear-gradient(#0000 10%,#00000080 100%)}.abs-line{border-radius:2px;height:2px;animation:2.5s ease-out infinite lineShoot;position:absolute}.abs-line-1{background:linear-gradient(270deg,#2196f3b3,#0000);animation-delay:0s;bottom:65%;right:0}.abs-line-2{background:linear-gradient(270deg,#2196f366,#0000);animation-delay:.5s;bottom:45%;right:0}.abs-line-3{background:linear-gradient(270deg,#ffffff1f,#0000);animation-delay:1s;bottom:80%;right:0}.abs-line-4{background:linear-gradient(270deg,#2196f380,#0000);animation-delay:1.5s;bottom:30%;right:0}.abs-line-5{background:linear-gradient(270deg,#ffffff14,#0000);animation-delay:2s;bottom:55%;right:0}.abs-line-6{background:linear-gradient(270deg,#2196f34d,#0000);animation-delay:.8s;bottom:72%;right:0}@keyframes lineShoot{0%{opacity:0;width:0}15%{opacity:1}to{opacity:0;width:65%}}.abs-glow{border-radius:50%;animation:4s ease-in-out infinite glowPulse;position:absolute}.abs-glow-1{background:radial-gradient(circle,#2196f31a 0%,#0000 60%);width:350px;height:350px;bottom:-30%;right:-15%}.abs-glow-2{background:radial-gradient(circle,#2196f30f 0%,#0000 60%);width:250px;height:250px;animation-delay:2s;top:-20%;left:-20%}@keyframes glowPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.abs-circle{border:1px solid #2196f31f;border-radius:50%;position:absolute}.abs-circle-1{width:180px;height:180px;animation:20s linear infinite circleRotate;top:10%;right:-40px}.abs-circle-2{border-style:dashed;border-color:#2196f314;width:120px;height:120px;animation:15s linear infinite reverse circleRotate;top:20%;right:-10px}.abs-circle-3{background:#2196f308;border-color:#2196f333;width:60px;height:60px;top:35%;right:20px}@keyframes circleRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.abs-particle{border-radius:50%;animation:5s ease-in-out infinite particleFloat;position:absolute}.abs-p1{background:var(--primary);width:4px;height:4px;animation-delay:0s;top:18%;right:22%}.abs-p2{background:#fff6;width:3px;height:3px;animation-delay:.8s;top:35%;right:12%}.abs-p3{background:#2196f380;width:5px;height:5px;animation-delay:1.5s;top:55%;right:30%}.abs-p4{background:#ffffff40;width:2px;height:2px;animation-delay:2.5s;top:25%;right:55%}.abs-p5{background:var(--primary);opacity:.6;width:3px;height:3px;animation-delay:1s;top:70%;right:18%}.abs-p6{background:#ffc10780;width:3px;height:3px;animation-delay:3.5s;top:12%;right:38%}.abs-p7{background:#ffffff26;width:2px;height:2px;animation-delay:.3s;top:45%;right:45%}.abs-p8{background:#2196f34d;width:4px;height:4px;animation-delay:2s;top:80%;right:50%}@keyframes particleFloat{0%,to{opacity:.2;transform:translateY(0)translate(0)}25%{opacity:.9;transform:translateY(-12px)translate(6px)}50%{opacity:.4;transform:translateY(-6px)translate(-4px)}75%{opacity:1;transform:translateY(-18px)translate(4px)}}.abs-watermark{color:#2196f30a;text-transform:uppercase;letter-spacing:8px;pointer-events:none;font-size:110px;font-weight:900;line-height:1;position:absolute;bottom:15%;right:-10px}.abs-chevrons{flex-direction:column;gap:2px;display:flex;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.abs-chev{border-top:2px solid #2196f34d;border-right:2px solid #2196f34d;width:16px;height:16px;animation:2s ease-in-out infinite chevPulse;transform:rotate(45deg)}.abs-chev-1{animation-delay:0s}.abs-chev-2{animation-delay:.15s}.abs-chev-3{animation-delay:.3s}.abs-chev-4{animation-delay:.45s}@keyframes chevPulse{0%,to{opacity:.15;border-color:#2196f326}50%{opacity:.9;border-color:#2196f399}}.abs-diag{background:#2196f30a;position:absolute;transform:rotate(-35deg)}.abs-diag-1{width:200px;height:3px;top:20%;right:-30px}.abs-diag-2{background:#2196f30f;width:150px;height:2px;top:28%;right:-20px}.abs-diag-3{background:#2196f308;width:100px;height:2px;top:34%;right:-10px}.hero-badge{color:#66bb6a;text-transform:uppercase;letter-spacing:1px;background:#4caf501f;border:1px solid #4caf5040;border-radius:20px;align-items:center;gap:6px;margin-bottom:14px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-flex}.hero-badge:before{content:"";background:#66bb6a;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite badgePulse}@keyframes badgePulse{0%,to{opacity:1}50%{opacity:.3}}.hero-separator{gap:6px;margin-top:14px;display:flex}.hero-separator span{background:var(--primary);border-radius:2px;height:3px;display:block}.hero-separator span:first-child{opacity:1;width:30px}.hero-separator span:nth-child(2){opacity:.5;width:16px}.hero-separator span:nth-child(3){opacity:.25;width:8px}.hero-bottom-bar{background:linear-gradient(90deg, var(--primary), #2196f366 50%, transparent);height:3px;position:absolute;bottom:0;left:0;right:0}.hero-content{top:calc(env(safe-area-inset-top,20px) + 20px);z-index:10;position:absolute;left:24px;right:24px}.hero-greeting{color:var(--text-light);margin-bottom:4px;font-size:14px;font-weight:500}.hero-name{color:var(--text-white);text-transform:uppercase;letter-spacing:-.5px;text-shadow:0 2px 20px #00000080;margin-bottom:6px;font-size:30px;font-weight:900}.hero-tagline{color:var(--primary);text-transform:uppercase;letter-spacing:2px;font-size:13px;font-weight:700}.accueil-stats{gap:10px;margin:20px 0 16px;display:flex}.stat-card{background:var(--bg-card);border:1px solid var(--border);text-align:center;cursor:pointer;border-radius:14px;flex:1;padding:16px 12px;transition:border-color .2s,transform .1s;position:relative;overflow:hidden}.stat-card:active{border-color:var(--primary);transform:scale(.97)}.stat-number{color:var(--text-white);margin-bottom:4px;font-size:28px;font-weight:900;line-height:1}.stat-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.stat-indicator{height:3px;position:absolute;top:0;left:0;right:0}.stat-dispo .stat-indicator{background:var(--primary)}.stat-dispo .stat-number{color:var(--primary)}.stat-afaire .stat-indicator{background:#ffc107}.stat-afaire .stat-number{color:#ffc107}.stat-done .stat-indicator{background:#4caf50}.stat-done .stat-number{color:#66bb6a}.accueil-cta{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);text-align:left;border-radius:14px;align-items:center;gap:14px;width:100%;margin-bottom:20px;padding:18px 20px;transition:transform .1s;display:flex}.accueil-cta:active{transform:scale(.98)}.cta-icon{background:#ffffff26;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.cta-text{flex:1}.cta-title{color:#fff;text-transform:uppercase;letter-spacing:.3px;font-size:16px;font-weight:800;display:block}.cta-sub{color:#fff9;margin-top:2px;font-size:12px;display:block}.cta-arrow{opacity:.6;flex-shrink:0}.accueil-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;display:grid}.grid-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:14px;padding:20px 16px;transition:border-color .2s,transform .1s;position:relative}.grid-card:active{border-color:var(--primary);transform:scale(.97)}.grid-icon{color:var(--primary);margin-bottom:10px}.grid-label{color:var(--text-white);font-size:14px;font-weight:700}.grid-badge{background:var(--primary);color:#fff;border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;font-size:11px;font-weight:800;display:flex;position:absolute;top:12px;right:12px}.accueil-version{text-align:center;color:var(--text-light);opacity:.5;padding:8px 0;font-size:12px}.announcement-banner{border:1px solid;border-radius:10px;align-items:center;gap:10px;margin:16px 0 4px;padding:12px 16px;font-size:13px;font-weight:600;animation:.4s ease-out bannerSlide;display:flex;overflow:hidden}.banner-text-wrap{flex:1;min-width:0;overflow:hidden}.banner-text-wrap span{white-space:nowrap}.announcement-banner.banner-scroll .banner-text-wrap span{animation:12s linear infinite bannerMarquee;display:inline-block}@keyframes bannerMarquee{0%{transform:translate(20%)}to{transform:translate(-100%)}}.announcement-banner.banner-scroll>span:last-child{min-width:max-content;padding-right:40px;animation-duration:18s}@keyframes bannerSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.banner-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s ease-in-out infinite dotPulse}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.banner-info{color:#6ab0f3;background:#4a90d914;border-color:#4a90d933}.banner-info .banner-dot{background:#4a90d9}.banner-warning{color:#ffd54f;background:#ffc10714;border-color:#ffc10733}.banner-warning .banner-dot{background:#ffc107}.banner-success{color:#81c784;background:#4caf5014;border-color:#4caf5033}.banner-success .banner-dot{background:#4caf50}.banner-danger{color:#ef9a9a;background:#ef535014;border-color:#ef535033}.banner-danger .banner-dot{background:#ef5350}.admin-section{border-top:1px solid var(--border);margin-top:28px;padding-top:24px}.admin-header{align-items:center;gap:10px;margin-bottom:14px;display:flex}.admin-badge{color:var(--danger);letter-spacing:1px;background:#ef53501f;border:1px solid #ef535033;border-radius:4px;padding:3px 8px;font-size:10px;font-weight:800}.admin-header h3{color:var(--text-white);font-size:16px;font-weight:700}.admin-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.admin-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;flex-direction:column;gap:8px;margin-bottom:14px;font-size:12px;font-weight:700;display:flex}.admin-label textarea{border:1px solid var(--border);background:var(--bg-input);color:var(--text-white);resize:vertical;border-radius:10px;min-height:60px;padding:12px;font-family:inherit;font-size:15px}.admin-label textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.admin-types{gap:8px;display:flex}.admin-type-btn{text-transform:uppercase;letter-spacing:.3px;background:var(--bg-input);color:var(--text-light);border:1px solid var(--border);border-radius:8px;flex:1;padding:8px 6px;font-size:12px;font-weight:700;transition:all .2s}.admin-type-btn.active{background:color-mix(in srgb, var(--type-color) 15%, transparent);color:var(--type-color);border-color:color-mix(in srgb, var(--type-color) 30%, transparent)}.admin-toggle-label{color:var(--text);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px;font-weight:600;display:flex}.admin-toggle{background:var(--bg-input);border:1px solid var(--border);cursor:pointer;border-radius:13px;width:48px;height:26px;transition:background .2s,border-color .2s;position:relative}.admin-toggle.on{background:var(--primary);border-color:var(--primary)}.admin-toggle-thumb{background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 4px #0000004d}.admin-toggle.on .admin-toggle-thumb{transform:translate(22px)}.admin-disabled-text{color:var(--text-light);text-align:center;padding:8px 0;font-size:14px}.sa-group-info{flex-direction:column;gap:0;display:flex}.sa-group-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.sa-group-row:last-child{border-bottom:none}.sa-group-label{color:var(--text-light);font-size:13px}.sa-group-value{color:var(--text-white);font-size:14px;font-weight:600}.sa-group-code{color:var(--primary);letter-spacing:1px;background:#2196f31f;border-radius:6px;padding:3px 10px;font-family:monospace;font-size:13px;font-weight:700}.sa-chat-container{max-height:calc(100dvh - 320px);overflow-y:auto}.sa-chat-list{flex-direction:column;gap:8px;display:flex}.sa-chat-msg{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:10px 14px}.sa-chat-sender{color:var(--primary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px;font-size:11px;font-weight:700}.sa-chat-text{color:var(--text);word-break:break-word;font-size:14px;line-height:1.4}.sa-chat-time{color:var(--text-light);text-align:right;margin-top:4px;font-size:11px}
